一个模板元函数来检查一个类是否有一个特定的成员

通过创建一个模板元函数来检查一个类是否有一个特定的成员。以下是一个例子:

cpp 复制代码
#include <type_traits>

template<typename T, typename = void>
struct has_type_member : std::false_type {};

template<typename T>
struct has_type_member<T,
std::void_t<typename T::type>> : std::true_type {};

struct Test {
    using type = double;
};

int main() {
    static_assert(has_type_member<Test>::value, "Test::type exists");
    static_assert(!has_type_member<int>::value, "int::type doesn't exist");
    return 0;
}

在这个例子中,has_type_member 是一个模板元函数,它检查其模板参数 T 是否有一个名为 type 的成员。它首先假设 T 没有 type 成员,然后通过模板特化来检查 T 是否真的有 type 成员。

如果 T::type 存在,那么 std::void_t<typename T::type> 就是 void,所以 has_type_member<T, std::void_t<typename T::type>> 就是 has_type_member<T, void>,这匹配了模板特化,所以 has_type_member<T>::valuetrue

如果 T::type 不存在,那么 std::void_t<typename T::type> 就会导致一个编译错误,但是由于模板参数的 SFINAE(Substitution Failure Is Not An Error)特性,这个错误会被忽略,然后编译器就会选择 has_type_member<T, void> 的主模板,所以 has_type_member<T>::valuefalse

所以,你可以使用 has_type_member<T>::value 来检查一个类型 T 是否有一个 type 成员。

扩展:

SFINAE 是 "Substitution Failure Is Not An Error" 的缩写,它是 C++ 模板元编程中的一个重要概念。

在模板实例化过程中,编译器会尝试用具体的类型替换模板参数。这个替换过程有时可能会失败,例如当我们尝试调用一个不存在的函数或访问一个不存在的成员。在大多数情况下,这种替换失败将导致编译错误。但在某些情况下,C++ 标准允许这种替换失败,并且不会产生编译错误,这就是 SFINAE 的原理。

相关推荐
再睡一夏就好1 分钟前
string.h头文件中strcpy、memset等常见函数的使用介绍与模拟实现
c语言·c++·笔记·string·内存函数·strcpy
dangdang___go3 分钟前
动态内存管理||malloc和free.realloc和calloc
c语言·开发语言·算法·动态内存管理
YA33313 分钟前
mcp-grafana mcp 使用stdio报错
java·开发语言
周杰伦_Jay15 分钟前
【Go 语言主流 Web】 框架详细解析
开发语言·后端·微服务·架构·golang
cpp_250116 分钟前
P5412 [YNOI2019] 排队
数据结构·c++·算法·题解·洛谷
kingmax5421200830 分钟前
图论核心算法(C++):包括存储结构、核心思路、速记口诀以及学习方法, 一站式上机考试学习【附PKU百练,相关练习题单】
c++·算法·图论·信奥赛·上机考试·百练·pku
罗湖老棍子33 分钟前
【例9.15】潜水员(信息学奥赛一本通- P1271)
c++·算法·动态规划·二维费用背包
PfCoder1 小时前
WinForm真入门(20)——StatusStrip控件解析
开发语言·windows·c#·winform·statusstrip
灵犀坠1 小时前
前端面试八股复习心得
开发语言·前端·javascript
代码游侠1 小时前
学习笔记——数据结构学习
linux·开发语言·数据结构·笔记·学习