【C++模板】typename关键字的用法

简介: 【C++模板】typename关键字的用法

关键字typename

作为一个C++程序员我想对于typename关键字都应该不陌生。不就是用于声明一个模板参数吗?

template<typename T>
void print(T t)
{
  std::cout << t << std::endl;
}

但是你有没有想过在声明模板参数时还可以用class关键字。那么委员会又为什么会有这种冗余的设计呢?

分析起源

class关键字可以表示一个类的声明,还可以表示一个模板参数。早期这样设计是为了避免增加不必要的关键字,后来委员会认为这样混用可能会造成关键字的功能混淆。为此引入了typename关键字。

场景分析

而且在未引入typename关键字之前。无法解决下面这个场景。这里的T::SubType编译器无法知道这是一个类型还是一个静态成员变量。

template<typename T>
class MyClass
{
  T::SubType* ptr;
};

1、假如SubType是一个静态成员,那么T::SubType* ptr就被看作是类T的静态成员SubType与ptr变量的乘积。这时如果ptr没有定义将会在模板实例化时报错。

2、假如SubType是一个类型,那么ptr就是一个指向T::SubType类型的指针。

看看C++标准怎么说

对于 使用模板定义的且依赖于模板参数的名称,只有在实例化的参数中存在这个类型或者这个名称前面使用typename关键字来修饰,编译器才会将这个名称当作一个类型。

可以看下面这个简单的例子。

template<typename T>
void printcoll(T const& coll)
{
  typename T::const_iterator pos;
  typename T::const_iterator end(coll.end());
  for (pos = coll.begin(); pos != end; ++pos)
  {
    std::cout << *pos << " ";
  }
  std::cout << std::endl;
}


typename在下面情况下禁止使用

1、模板定义之外,即typename只能用于模板的定义中

2、非限定类型,比如int,vector之类

3、基类列表中,比如template class C1 : T::InnerType不能在T::InnerType前面加typename

4、构造函数的初始化列表中 如果类型是依赖于模板参数的限定名,那么在它之前必须加typename(除非是基类列表,或者在类的初始化成员列表中)。

目录
相关文章
|
6天前
|
程序员 C++
C++模板元编程入门
【7月更文挑战第9天】C++模板元编程是一项强大而复杂的技术,它允许程序员在编译时进行复杂的计算和操作,从而提高了程序的性能和灵活性。然而,模板元编程的复杂性和抽象性也使其难以掌握和应用。通过本文的介绍,希望能够帮助你初步了解C++模板元编程的基本概念和技术要点,为进一步深入学习和应用打下坚实的基础。在实际开发中,合理运用模板元编程技术,可以极大地提升程序的性能和可维护性。
|
17天前
|
安全 编译器 C++
C++一分钟之-编译时计算:constexpr与模板元编程
【6月更文挑战第28天】在C++中,`constexpr`和模板元编程用于编译时计算,提升性能和类型安全。`constexpr`指示编译器在编译时计算函数或对象,而模板元编程通过模板生成类型依赖代码。常见问题包括误解constexpr函数限制和模板递归深度。解决策略包括理解规则、编写清晰代码、测试验证和适度使用。通过实战示例展示了如何使用`constexpr`计算阶乘和模板元编程计算平方。
36 13
|
14天前
|
存储 编译器 C++
【C++】详解C++的模板
【C++】详解C++的模板
|
4天前
|
Java 编译器 Linux
【c++】模板进阶
本文详细介绍了C++中的模板技术,包括非类型模板参数的概念、如何使用它解决静态栈的问题,以及模板特化,如函数模板特化和类模板特化的过程,以提升代码的灵活性和针对性。同时讨论了模板可能导致的代码膨胀和编译时间增加的问题。
7 2
|
4天前
|
存储 安全 编译器
【C++入门 四】学习C++内联函数 | auto关键字 | 基于范围的for循环(C++11) | 指针空值nullptr(C++11)
【C++入门 四】学习C++内联函数 | auto关键字 | 基于范围的for循环(C++11) | 指针空值nullptr(C++11)
|
13天前
|
C++ 开发者
C++一分钟之-编译时计算:constexpr与模板元编程
【7月更文挑战第2天】C++的`constexpr`和模板元编程(TMP)实现了编译时计算,增强代码效率。`constexpr`用于声明编译时常量表达式,适用于数组大小等。模板元编程则利用模板进行复杂计算。常见问题包括编译时间过长、可读性差。避免方法包括限制TMP使用,保持代码清晰。结合两者可以解决复杂问题,但需明确各自适用场景。正确使用能提升代码性能,但需平衡复杂性和编译成本。
33 3
|
12天前
|
编译器 C语言 C++
【C++】模板初阶(下)
C++的函数模板实例化分为隐式和显式。隐式实例化由编译器根据实参推断类型,如`Add(a1, a2)`,但`Add(a1, d1)`因类型不一致而失败。显式实例化如`Add&lt;double&gt;(a1, d1)`则直接指定类型。模板函数不支持自动类型转换,优先调用非模板函数。类模板类似,用于创建处理多种数据类型的类,如`Vector&lt;T&gt;`。实例化类模板如`Vector&lt;int&gt;`和`Vector&lt;double&gt;`创建具体类型对象。模板使用时,函数模板定义可分头文件和实现文件,但类模板通常全部放头文件以避免链接错误。
|
12天前
|
机器学习/深度学习 算法 编译器
【C++】模板初阶(上)
**C++模板简介** 探索C++泛型编程,通过模板提升代码复用。模板作为泛型编程基础,允许编写类型无关的通用代码。以`Swap`函数为例,传统方式需为每种类型编写单独函数,如`Swap(int&)`、`Swap(double&)`等,造成代码冗余。函数模板解决此问题,如`template&lt;typename T&gt; void Swap(T&, T&)`,编译器根据实参类型推导生成特定函数,减少重复代码,增强可维护性。模板分函数模板和类模板,提供处理不同数据类型但逻辑相似的功能。
|
12天前
|
算法 编译器 程序员
|
12天前
|
存储 编译器 程序员