__STL_CLASS_PARTIAL_SPECIALIZATION

本文深入探讨了C++中模板特化的概念,包括全特化和偏特化,并通过具体实例展示了如何在类模板和函数模板中应用这些特化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//in <stl_config.h>
# ifdef __STL_CLASS_PARTIAL_SPECIALIZATION
#   define __STL_TEMPLATE_NULL template<>
# else
#   define __STL_TEMPLATE_NULL
# endif
 

...

//in <type_traits.h>
template <class type> struct __type_trains {...};
__STL_TEMPLATE_NULL struct __type_traits<char> { ... };

//in <stl_hash_fun.h>
template <class type> struct hash {};
__STL_TEMPLATE_NULL struct hash<char> { ... };
__STL_TEMPLATE_NULL struct hash<unsigned char> { ... };


http://blog.youkuaiyun.com/thefutureisour/article/details/7964682

模板为什么要特化,因为编译器认为,对于特定的类型,如果你能对某一功能更好的实现,那么就该听你的。

模板分为类模板与函数模板,特化分为全特化与偏特化。全特化就是限定死模板实现的具体类型,偏特化就是如果这个模板有多个类型,那么只限定其中的一部分。

先看类模板:

  1. template<typename T1, typename T2>  
  2. class Test  
  3. {  
  4. public:  
  5.     Test(T1 i,T2 j):a(i),b(j){cout<<"模板类"<<endl;}  
  6. private:  
  7.     T1 a;  
  8.     T2 b;  
  9. };  
  10.   
  11. template<>  
  12. class Test<int , char>  
  13. {  
  14. public:  
  15.     Test(int i, char j):a(i),b(j){cout<<"全特化"<<endl;}  
  16. private:  
  17.     int a;  
  18.     char b;  
  19. };  
  20.   
  21. template <typename T2>  
  22. class Test<char, T2>  
  23. {  
  24. public:  
  25.     Test(char i, T2 j):a(i),b(j){cout<<"偏特化"<<endl;}  
  26. private:  
  27.     char a;  
  28.     T2 b;  
  29. };  

那么下面3句依次调用类模板、全特化与偏特化:
  1. Test<double , double> t1(0.1,0.2);  
  2. Test<int , char> t2(1,'A');  
  3. Test<charbool> t3('A',true);  

而对于函数模板,却只有全特化,不能偏特化:
  1. //模板函数  
  2. template<typename T1, typename T2>  
  3. void fun(T1 a , T2 b)  
  4. {  
  5.     cout<<"模板函数"<<endl;  
  6. }  
  7.   
  8. //全特化  
  9. template<>  
  10. void fun<int ,char >(int a, char b)  
  11. {  
  12.     cout<<"全特化"<<endl;  
  13. }  
  14.   
  15. //函数不存在偏特化:下面的代码是错误的  
  16. /* 
  17. template<typename T2> 
  18. void fun<char,T2>(char a, T2 b) 
  19. { 
  20.     cout<<"偏特化"<<endl; 
  21. } 
  22. */  

至于为什么函数不能偏特化,似乎不是因为语言实现不了,而是因为偏特化的功能可以通过函数的重载完成。
本关任务:掌握模板的特化与偏特化。 相关知识 “凡事都有特例”,程序设计中的普遍规律。对于某些模板类,存在“过于宽泛”的问题 —— 某些方法针对一般模板参数(如T)的实现,未必适用于某些特定的参数类型。 考虑下面的例子:假设有按照如下方式声明的类 template<typename T> class Spec{ private: T value; public: Spec(const T &); ~Spec(); public: bool operator==(const Spec&) const; }; 它对算符 == 进行了重载 —— 只有两个 Spec<T> 对象的 value 成员相同时,才返回真(1)。然而,这对于T为char*的情况是不适用的,因为我们希望当两个Spec<char*> 对象的value指向字符串内容相同时即返回真(而无需要求value对应的地址相同)。 此时,需要对 Spec<T> 类进行特化,即对 Spec<char*> 进行特殊处理。特化时,需要按如下方式进行类声明 template<> // 取消模板参数 class Spec<char*>{ private: char* value; public: Spec(char *); ~Spec(); public: bool operator==(const Spec<char*>&); }; 接下来,你需要实现Spec<char*>类的各个方法(请在/**********begin ********/ 和 /********** end ********/之间完成)。 此外,模板参数还存在“偏特化”(也成为“部分特化”)的概念。偏特化分为两种情况: 第一,类模板中含有多个类型参数,将某些类型参数固定为特定类型; 第二,将类模板中的类型参数限制为某种特定形式,如指针等。 关于模板类的偏特化问题,感兴趣的同学可以进一步查阅相关资料。 开始你的任务吧,祝你成功!
最新发布
05-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值