为什么type_traits使用结构实现

Why is type_traits implemented using structs

本文关键字:结构 实现 traits type 为什么      更新时间:2023-10-16

大多数类型特征都是使用结构和模板部分(或完全(专用化的。例如,std::is_same实现为

template<typename>
struct is_same : false_type {};
template<typename T>
struct is_same<T, T> : true_type {}; // partial specialization

用法将是

bool are_equal = std::is_same<T, U>::value;

.. = std::is_same_v<T, U>;

这两者都有点丑。 起初我认为这是唯一的解决方案,然后我发现变量也可以部分专用(而函数不能(。 类型转换特征不能(明显地(是变量,但对于"信息"特征,为什么这不会比结构更好?

template<typename>
inline constexpr bool is_same = false;
template<typename T>
inline constexpr bool is_same<T, T> = true;

然后

bool are_equal = std::is_same<T, U>;

原因仅仅是历史原因。大多数类型特征在 C++11 中首先添加到库中。变量模板是在 C++14 年晚些时候添加的,更改实现是不可行的,因为这太向后不兼容了。因此,添加了带有_v后缀的变量,这成为惯例。

添加新特征的方式相同,因为在任何库中保持一致性都很重要,更不用说标准库了。

有时,您需要一个类型,而不仅仅是基础bool值。标签调度技术提供了简单示例:

void foo(std::true_type)  { ... }
void foo(std::false_type) { ... }
foo(std::is_same<T, S>{});

如果std::is_same只是一个bool变量模板,那么这段代码就不会那么优雅。

请注意,类型和非类型参数不可互换。不能编写接受两者的一元模板。如果要构建一个成熟的编译时计算代数,则需要选择一种参数类型,并使所有模板仅接受该参数类型。