MSVC - 使用 void_t 进行成员检测无法正常工作
MSVC - Member detection with void_t doesn't work properly
我前几天遇到过这种情况。
#include <iostream>
#include <type_traits>
using namespace std;
template<typename... Ts> struct make_void { typedef void type; };
template<typename... Ts> using void_t = typename make_void<Ts...>::type;
template <class, class = void>
struct is_func_chrend_ : std::false_type {};
template <class T>
struct is_func_chrend_<T, ::void_t<decltype(std::declval<T>().NextTile())>> : std::true_type {};
template <class = void, class = void>
struct is_addable : std::false_type {};
template <class T>
struct is_addable<T, ::void_t<decltype(std::declval<T>() + std::declval<T>())>> : std::true_type {};
int main() {
cout << is_addable<int>::value << endl;
return 0;
}
在MSVC中编译时显示0,在clang或gcc中编译时显示1。完全去除is_func_chrend_
使is_addable
重新正常工作
临时void_t
仅用于c++ 11兼容的编译器
MSVC尚未发布兼容c++ 11的编译器。
他们最大的问题是decltype
在SFINAE环境中使用。
他们定期改善情况,使越来越多的decltype
案例工作,但它并不可靠。
当事情出错时,它被破坏的方式经常产生假阳性和假阴性,并且失败是非局部的,因为您以前使用SFINAE表达式的方式可以改变下一次成功或失败的方式。
你根本不能在MSVC中安全地使用基于decltype的SFINAE,除非你仔细解码你的MSVC特定版本可以处理的内容,并且永远不要离开这些界限。我个人觉得他们对哪些是可行的,哪些是不可行的描述不够清楚,我觉得我可以可靠地使用它。
相关文章:
- QSqlquery prepare()和bindvalue()不工作
- 导入库可以跨dll版本工作吗
- 以螺旋方式打印矩阵的程序.(工作不好)
- 对象指针在c++中是如何工作的
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- VSOMEIP-2个设备之间的通信(TCP/UDP)不工作
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++为线程工作动态地分割例程
- 为什么我的 std::ref 无法按预期工作?
- 布尔比较运算符是如何在C++中工作的
- SampleConsensusPrerejective(ext.RANSAC)是如何真正工作的
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 为什么std::condition_variable notify_all的工作速度比notify_one快(对于随机请
- <<操作员在下面的行中工作
- 有人能解释一下为什么下界是这样工作的吗C++的
- ExtractIconEx:可以工作,但偶尔会崩溃
- C++中的memset函数工作不正常
- 当我在第一个循环中使用"auto"时,它工作正常,但是使用"int"它会给出错误,为什么?
- 为什么STD ::计数将常数传递给Lambda,而不是在弦上工作时而不是字符
- C++程序已停止工作-求解常微分方程