【问题标题】:How to replace std::is_same_v with std::is_same如何用 std::is_same 替换 std::is_same_v
【发布时间】:2020-10-10 10:05:53
【问题描述】:

我有这个包含std::is_same_v 的代码可用于 C++17。但由于工具链的限制,我一直坚持使用 C++14。

template<class T, class O = T>
using IteratorOnly = std::enable_if_t<
    !std::is_same_v<typename std::iterator_traits<T>::value_type, void>, O
>;

如何将std::is_same_v 替换为std::is_same?是否有任何解决方法可以仅使用 C++14 编译代码?

【问题讨论】:

  • std::is_same&lt;typename std::iterator_traits&lt;T&gt;::value_type, void&gt;::value.
  • 检查例如this std::is_same reference。它显示了std::is_same_v 的(可能的)定义,应该可以从中反转它以获得std::is_same 的用法。

标签: c++ std


【解决方案1】:

@Someprogrammerdude 关于 is_same_v 帮助变量模板 定义的 here 的评论解决了该错误。我的最终代码是

#ifdef My_OLD_TOOL_CHAIN

template< class T, class U >
inline constexpr bool is_same_v = std::is_same<T, U>::value;

template<class T, class O = T>
using IteratorOnly = std::enable_if_t<
    !is_same_v<typename std::iterator_traits<T>::value_type, void>, O
>;

#else // My_OLD_TOOL_CHAIN

template<class T, class O = T>
using IteratorOnly = std::enable_if_t<
    !std::is_same_v<typename std::iterator_traits<T>::value_type, void>, O
>;

#endif // My_OLD_TOOL_CHAIN

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-01-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-07-05
相关资源
最近更新 更多