类模板函数使用时实例化说明

这个规则的一个有意思的结果就是:如果传递的类型仅使唤部分类成员函数合法,只要调用不到,不影响类模板使用。

以下代码是个展示例子

template<typename _T>
class Tpl
{
public:
    void fun1(_T o)
    {
        char data[o];
        cout << sizeof(data) << endl;
    }
    void fun2(_T o)
    {
        cout << o.size() << endl;
    }
};
int main(int argc, char* argv[])
{
    Tpl<int> t1;
    t1.fun1(3);
    //t1.fun2(3);           //非法,但不影响模板实例化
    Tpl<string> t2;
    //t2.fun1("abcdefg");   //非法,但不影响模板实例化
    t2.fun2("abcdefg");
    return 0;
}


如果这个效果不是自己所希望的,则可以显示实例化,显示实例化会实例化所有成员,检查非法

template class Tpl<int>;
template class Tpl<string>;

源文件是独立编译的,每一次实例化都可能产生重复的实例类,这可能是难以接受的,解决办法是声明为外部定义,这样遇到模板使用时,不会实例化,而是链接外部,确保存在一次定义,否则会报链接错误

extern template class Tpl<int>;
extern template class Tpl<string>;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值