C++模板元编程 实测2
第一章习题5:
使用SFINAE构造一个元函数:输入一个类型T,当T存在子类型type时该元函数返回true,否则返回false。
copilot给出的答案是
// 检测嵌套类型type存在的版本 template <typename T> auto has_type_impl(int) -> decltype(std::declval<typename T::type>(), std::true_type{}); // 检测嵌套类型type不存在的版本 template <typename T> std::false_type has_type_impl(...); // 元函数,返回是否存在嵌套类型type template <typename T> constexpr bool has_type = decltype(has_type_impl<T>(0))::value;
注意:
- 不能将
...
改为int
,因为这样无法决定使用哪个函数。 decltype(std::declval<typename T::type>(), std::true_type{})
使用了逗号表达式,返回值是右侧std::true_type{}
。
也可以这么写:
template<typename T, typename T::type* = nullptr> constexpr bool has_subtype(int) { return true; } template<typename T> constexpr bool has_subtype(...) { return false; } template<typename T> constexpr bool has_subtype_t = has_subtype<T>(0);
同样,这里利用了...
较低的优先级,如果不增加int
和...
,无法通过编译。这种写法更接近熟悉的SFINAE。
另一种可行的写法:
template<typename T, typename U = void> struct has_subtype : std::false_type {}; template<typename T> struct has_subtype<T, std::void_t<typename T::type>> : std::true_type {}; template<typename T> constexpr bool has_subtype_t = has_subtype<T>::value;
我们不能省略std::void_t
,如果我们省略它,第二个模板不会起效,具体原因未知(copilot认为可能是编译器无法正确解析嵌套类型)。:<
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具