发信人: hhuu (我爱XXX), 信区: Programming
标 题: boost::ref
发信站: BBS 水木清华站 (Sat May 25 02:03:27 2002)
1, 简介
(原来确实是我错了,本来只是想简单说明一下ref为什么需要,
结果例子太简单,laws提了意见,检查一下,确实词不达意。
重新说明一下,请大家重新审阅。)
ref存在的目的,就是对于一个模版函数,在传值和传引用都
可以的时候,把选择的权利下放给使用者。(如果是临时变量,
就不应该用ref;否则的就应该尽量用ref。)
简单的想法,就是用函数重载的方法。不过这个方法没法实现。
如果模版函数可以偏特化,那也是个不错的方法,可惜这个方法
甚至没有进到ansi标准里面去。
2, 使用
ref就是用在这样的场合,在参数上套一个ref(),显式告诉编译器
这里用引用传递;否则的话,就是值传递。
sample:
#include <iostream>
#include <boost/ref.hpp>
//#include <boost/type_traits.hpp>
using namespace std;
using namespace boost;
struct QQ{
int k;
};
template <typename T>
int
foo(T a){
//(add_reference<unwrap_reference<T>::type>::type(a)).k = 10;
typedef unwrap_reference<T>::type& truetype;
truetype k = a; k.k = 10; return 0;
}
int main()
{
QQ huxw;
sample:
#include <iostream>
#include <boost/ref.hpp>
//#include <boost/type_traits.hpp>
using namespace std;
using namespace boost;
struct QQ{
int k;
};
template <typename T>
int
foo(T a){
//(add_reference<unwrap_reference<T>::type>::type(a)).k = 10;
typedef unwrap_reference<T>::type& truetype;
truetype k = a; k.k = 10; return 0;
}
int main()
{
QQ huxw;
foo(ref(huxw));
cout << huxw.k << endl;
huxw.k = 11; foo(huxw);
cout << huxw.k << endl;
return 0;
}
3, 实现
这样一个类,效率是非常重要的,不然就是画虎不成反类犬了。;)
引用传递,想想和指针传递也没什么两样啊。;)
对了,就是用指针实现的。
template<class T>
class reference_wrapper
{
public:
typedef T type;
explicit reference_wrapper(T& t): t_(&t) {}
//保存下t的地址
operator T& () const { return *t_; }
//这里巧妙的用了一个类型转换操作符。沟通了reference_wapper和T&这两个类。
T& get() const { return *t_; }
T* get_pointer() const { return t_; }
private:
T* t_;
};
由此可见,ref和cref无非是返回了一个reference_wapper类而已。
四, 其他
这个东西boost::ref,简单巧妙,确实很有意思。
--
※ 修改:·hhuu 於 May 25 21:44:44 修改本文·[FROM: 166.111.172.6]
※ 来源:·BBS 水木清华站 smth.edu.cn·[FROM: 166.111.172.6]