《Effective C++》Rule42: 了解 typename 的双重意义
2016-03-05 13:20
387 查看
在 t下面 template 声明式中,class 和 typename 意义完全相同。
然而 C++ 并不总是把 class 和 typename 视为等价。 有时候,我们一定得使用typename。
一般来说,在缺省状态下,C++解析器认为在 template 中的嵌套从属名称是个变量,而不是个类型。
如果要告诉解析器,T::const_iterator 是一个类型,只需要在它之前加一个关键字: typename即可。
如:
但是,“template 必须作为嵌套从属类型名称的前缀词”也是有例外的。
typename 不可以出现在 base classes list内的嵌套从属类型名称之前,
也不可以出现在member initialization list中作为base class修饰符。
例如:
template <class T> class Widget; template <typename T> class WIdget;
然而 C++ 并不总是把 class 和 typename 视为等价。 有时候,我们一定得使用typename。
一般来说,在缺省状态下,C++解析器认为在 template 中的嵌套从属名称是个变量,而不是个类型。
如果要告诉解析器,T::const_iterator 是一个类型,只需要在它之前加一个关键字: typename即可。
如:
template <typename T> void Func(const T& container) { typename T::const_iterator iter; // ... ... }
但是,“template 必须作为嵌套从属类型名称的前缀词”也是有例外的。
typename 不可以出现在 base classes list内的嵌套从属类型名称之前,
也不可以出现在member initialization list中作为base class修饰符。
例如:
template <typename T> class Derived : public Base<T>::Nested // base classes list 不允许 “typename”. { public: explicit Derived(int x) : Base<T>::Nested(x) //不可以出现在member initialization list中作为base class修饰符 { typename Base<T>::Nested temp; //... ... } //... ... };
相关文章推荐
- C++中的析构函数为什么通常为虚函数
- C语言获取系统当前时间转化成时间字符串
- C++项目文件中的后缀名为SDF的文件是什么?有什么用?
- c++primer(第五版) 第十章 泛型算法习题答案
- 【总结】逆置双向链表的三种方法
- 重拾c语言——指针与数组
- POJ1190
- C语言解释器的实现--序(零)
- C++ 17 的最新动态
- C++容器详解
- C语言调用动态库中的函数的方法(dlopen,dlsym等)
- c语言概述
- vs2013 c++項目轉 vs2008
- C/C++ 声卡编程代码
- C++类的静态成员(static members in classes)
- C++拷贝构造函数
- 堆排序的c++实现代码
- C++中值传递、指针传递、引用传递
- C++学习笔记:异常的基本语法
- C语言易错的优先级