std::enable_if 学习

本文探讨了C++11中的std::enable_if,解释了为何仅凭默认模板参数不同的两个函数模板会被视为同一模板的重新声明,并通过示例说明了std::enable_if在SFINAE中的作用。虽然std::enable_if_t的模板类型可以灵活使用,但特定形式可能导致编译错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

std::enable_if

标准库文档这样写到:

辅助类型

template< bool B, class T = void >
using enable_if_t = typename enable_if<B,T>::type;

  (C++14 起)
     

可能的实现

template<bool B, class T = void>
struct enable_if {};
 
template<class T>
struct enable_if<true, T> { typedef T type; };

这个东西标准文档里写的很清楚,看代码也能看明白,但是,在标准文档里面的注释,属实把我整蒙了。

 

注解

常见错误是声明二个函数模板,而它们仅于其默认模板实参相异。这是无效的,因为这些函数声明被当做同一函数模板的再声明(默认模板实参不为函数模板等价所考虑)。

 

可能翻译的不太好,我又查了英文版同样的内容

 

Notes

A common mistake is to declare two

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值