成员函数模板

真实指针支持隐式转换:1)Derived class指针可以隐式转换为Base class指针;2)"指向non-const对象"的指针可以转换成"指向const对象"的指针。

智能指针:必须编写一个成员函数模板。因为我们无法写出所有的智能指针的构造函数,一旦Derived体系有新的补充就又要根据其他智能指针构造自己,实在太多了,根本不能写完。

因为一个template可以被无限量具现化,以至于生成无限量函数,所以我们不写构造函数,而是写一个构造模板,称为成员函数模板。

 

成员函数模板:

根据自己的理解,我认为成员函数模板其实就是放在class里面的函数模板。

如果声明member template用于"泛化copy构造"或"泛化assignment操作",你还是需要声明正常的copy构造函数和copy assignment操作符。

什么叫泛化构造函数呢?

template<class T>

classshared_ptr{

public:

template<class Y>

    explicit shared_ptr(Y* p);

template<class Y>

    shared_ptr(shared_ptr<Y> const& r); //泛化copy构造函数

template<class Y>

    explicit shared_ptr(weak_ptr<Y> const& r);

template<class Y>

    explicit shared_ptr(auto_ptr<Y> const& r);

template<class Y>

    shared_ptr& operator=(shared_ptr<Y> const& r); //赋值

template<class Y>

    shared_ptr& operator=(auto_ptr<Y> const& r);

……

};

 

当T和Y类型一样时,泛化copy构造函数就是普通的copy构造函数了。

posted @ 2016-07-29 10:54  秋水小战士  阅读(751)  评论(0编辑  收藏  举报