#include <type_traits>
template< typename T >
using cond =
std::conditional_t<
std::is_void< T >::value ,
std::true_type ,
std::false_type
>::value;
static_assert( cond< void > , "" );
int main() {}
missing 'typename' prior to dependent type name 'std::conditional_t::value, std::true_type, std::false_type>::value'
为什么它缺少typename
,因为它根本不是一种类型?
如果我添加typename
,它会向我抛出:
error: typename specifier refers to non-type member 'value' in 'std::integral_constant<bool, true>'
它与here中的相同吗? 我该如何解决这个问题?
答案 0 :(得分:2)
您只能将template aliases用于别名类型。您的变量模板的正确语法是
template< typename T >
constexpr bool cond = std::conditional_t< std::is_void< T >::value,
std::true_type,
std::false_type >::value;
虽然您的代码获取的错误消息有点令人困惑,但添加建议的typename
会产生更有用的消息,其中包含clang 3.6
error: typename specifier refers to non-type member 'value' in
'std::integral_constant'
using cond = typename std::conditional_t< std::is_void< T >::value,
^~~~~ std::true_type,
std::false_type >::value;
解释了真正的问题。