【C++学习笔记】typename 声明内嵌类型

文章讲述了在C++编程中,当涉及到模板类的依赖类型时,如何使用typename关键字消除编译器的歧义。通过示例解释了在声明和使用如HashTable<K>::iterator这样的依赖类型时,需要typename来指示其为类型,而非变量。同时,typedef也被用来创建类型别名。
摘要由CSDN通过智能技术生成

1、例子

#include "iostream"
using namespace std;
template<class K>
class HashTableIterator {
};
template<class K>
class HashTable {
public:
    typedef HashTableIterator<K> iterator;
    typedef int it;
    static const int b = 10;
    int a;
};
template<class K>
class myUnorderSet {
public:
    typename HashTable<K>::it i = 1;
    HashTable<K>::iterator a
    typedef HashTable<K>::iterator b;
};

int main(){
    HashTable<int>::it a = 10;
    cout << a << endl;
    typedef HashTable<int>::it i;
    return 0;
}

在这里插入图片描述

Missing ‘typename’ prior to dependent type name ‘HashTable::iterator’

2、解释

对于用于模板定义的依赖于模板参数的名称,只有在实例化的参数中存在这个类型名,或者这个名称前使用了 typename 关键字来修饰,编译器才会将该名称当成是类型。除了以上这两种情况,绝不会被当成是类型。

也就是说HashTable<K>::iterator a编译器根本不知道iterator是个啥,是变量还是类型?默认编译器是识别为变量的,因此clion检测到了错误,vs中就不会有红色波浪形提示。

因此,如果你想直接告诉编译器 HashTable<K>::iterator 是类型而不是变量,只需用 typename修饰:typename HashTable<K>::it,这样编译器就可以确定 HashTable<K>::iterator 是一个类型,而不再需要等到实例化时期才能确定,因此消除了前面提到的歧义。

而自己写迭代器时,还用了typedef,变成typedef typename HashTable<K>::iterator b;将b声明为iterator类型的别名。

3、综上

要用到一个类模版里面定义的类型时,要么在用这个类模版里面定义的类型时前面加上typename,要么将这个类模版实例化

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值