看侯捷老师讲智能指针的课程的时候,有那么一些感悟,其实这节课里讲的智能指针还不是很完全,通过之后的学习,我发现智能指针其实里面会有成员模板,来模拟我们平时会对变量进行的一个向上转型,最后达到可以使用虚函数的目的。
对于一个class去模拟point,我们必须对其*和->操作符进行重载。shared_ptr
template<typename T>
class shared_prt{
public:
T& operator*() const{
return *px;
}
T* operator->() const{
return px;
}
private:
T* px;
long* pn;
};
在调用的时候比如制造一个FOO的智能指针去使用它
struct FOO{
...
void method(){}
};
shared_prt<FOO> sp(new FOO);
FOO f(*sp);
sp->method();
智能指针里面一定会有一个指针去模拟这个指针,被封装在智能指针里,在智能指针里比较有用的是能够把封装在里面的指针使用析构函数进行资源管理。
另一个比较复杂的像指针的class就是迭代器了
这里也重载了很多操作符,最关键的还是*以及-> ,星号取出了这个node指针的data数据,->则是利用了*操作符重新取回原地址来实现的。
接下来看看仿函数,仿函数其实就是在class重载了运算符()
比如对于pair来说,我要取其第一个值。设计一个这样的class
template<class Pair>
struct select1st{
const typename Pair::first_type&
operator()(const Pair& x) const{ return x.first;}
};
形如这样的类,就可以成为类的仿函数,这时候我可以产生一个select1st<pair> a;
pair<int,int> x = (1,2);
a(x);
仿函数都会继承2种类型,unary_function(1个操作数),binary_function(2个操作数)。