typename enable_if<is_class<T>::value>::type = 0
не имеет смысла, потому что typename enable_if<is_class<T>::value>::type
будет означать void
; Вы можете изменить его на typename enable_if<is_class<T>::value>::type* = nullptr
. Затем для полной специализации int
обратите внимание, что test
имеет два параметра шаблона, затем
// Declaration
template <typename T, typename enable_if<is_class<T>::value>::type* = nullptr>
void test(T& value);
template <typename T, typename enable_if<!is_class<T>::value>::type* = nullptr>
void test(T& value);
template <>
void test<int, nullptr>(int& value);
// Definition
template <typename T, typename enable_if<is_class<T>::value>::type*>
void test(T& value) {
cout << "Class/struct test" << endl;
}
template <typename T, typename enable_if<!is_class<T>::value>::type*>
void test(T& value) {
cout << "Other types test" << endl;
}
template <>
void test<int, nullptr>(int& value) {
cout << "int test" << endl;
}
ЖИТЬ
Или просто укажите typename enable_if<is_class<T>::value>::type
в качестве типа возврата. например,
// Declaration
template <typename T>
typename enable_if<is_class<T>::value>::type test(T& value);
template <typename T>
typename enable_if<!is_class<T>::value>::type test(T& value);
template <>
void test<int>(int& value);
// Definition
template <typename T>
typename enable_if<is_class<T>::value>::type test(T& value) {
cout << "Class/struct test" << endl;
}
template <typename T>
typename enable_if<!is_class<T>::value>::type test(T& value) {
cout << "Other types test" << endl;
}
template <>
void test<int>(int& value) {
cout << "int test" << endl;
}
ЖИТЬ