写一个模板化的函数,我声明:
template <typename T>
T invertible(T const& container, T::size_type startIndex, T::size_type endIndex);
Run Code Online (Sandbox Code Playgroud)
用g ++ 4.0.1编译我得到了错误:
error: 'T::size_type' is not a type
Run Code Online (Sandbox Code Playgroud)
Tob*_*ias 29
您需要添加typename.
即
template <typename T>
T invertible(T const& container, typename T::size_type startIndex, typename T::size_type endIndex);
Run Code Online (Sandbox Code Playgroud)
如果没有关于类型T的任何信息,编译器需要知道T :: size_type指定一个类型.
从标准,第14.6.2节:
假定模板声明或定义中使用的名称以及依赖于模板参数的名称不会命名类型,除非适用的名称查找找到类型名称或名称由关键字限定
typename.
如您所知,T :: size_type需要以typename为前缀.为什么?
语言定义通过指定,一般依赖合格的名字并解决这个问题并不除非该名称与关键字类型名称前缀表示一个类型.
......是的类型名称前缀名称要求时名
- 出现在模板中
- 合格
- 不用作基类规范的列表,也不用于引入构造函数定义的成员初始化列表
- 依赖于模板参数
此外, 除非至少前三个条件成立,否则不允许使用typename前缀.
| 归档时间: |
|
| 查看次数: |
13271 次 |
| 最近记录: |