当我尝试使用MSCL 19编译以下代码时,它没问题。但是,当我尝试使用g ++ 6.2.0和clang 3.9.0时,我收到了类似expected nested-name-specifier class=typename
#include<type_traits>
using namespace std;
template<class T,class=typename enable_if_t<
is_signed<T>::value&&is_integral<T>::value&&(sizeof(T)>1)>>
void f(T i) {}
int main() {
f(1);
}
添加using std::enable_if_t
会产生相同的结果。
#include<type_traits>
using namespace std;
using std::enable_if_t;
template<class T,class=typename enable_if_t<
is_signed<T>::value&&is_integral<T>::value&&(sizeof(T)>1)>>
void f(T i) {
}
int main(){
f(1);
}
可以通过在enable_if_t
前加std::
:
#include<type_traits>
using namespace std;
template<class T,class=typename std::enable_if_t<
is_signed<T>::value&&is_integral<T>::value&&(sizeof(T)>1)>>
void f(T i) {
}
int main(){
f(1);
}
为什么using namespace std
和using std::enable_if_t
对std::enable_if_t
无效?
答案 0 :(得分:2)
它试图告诉你的是它何时看到typename
它希望下一个嵌套类型说明符。使用enable_if_t
时没有任何嵌套(无::
)。删除typename
会使其与gcc一起使用。