std::void_t是C++17中引入的,它其实是一个别名模板,源码非常简单,大概如下:
template<tpename...Args>
using void_t = void;
从源码来看,无论传入什么类型,也无论传入多少个类型,都会变成void类型。但是它有一个神奇的功能,它能够检测到应用SFINAE特性时非法的类型,也就是说,传入的类型必须是有效的类型,不能是非法的类型。
接下来看个例子:判断类中是否存在某个类型别名
struct hasType {
std::void_t是C++17引入的别名模板,用于类型检测,尤其在SFINAE原则下能有效识别非法类型。本文通过示例解释了如何利用std::void_t检测类中是否存在特定类型别名,以及如何通过宏定义提高代码复用性。
std::void_t是C++17中引入的,它其实是一个别名模板,源码非常简单,大概如下:
template<tpename...Args>
using void_t = void;
从源码来看,无论传入什么类型,也无论传入多少个类型,都会变成void类型。但是它有一个神奇的功能,它能够检测到应用SFINAE特性时非法的类型,也就是说,传入的类型必须是有效的类型,不能是非法的类型。
接下来看个例子:判断类中是否存在某个类型别名
struct hasType {
225
355

被折叠的 条评论
为什么被折叠?