Der folgende Code ist in Ordnung:
template <class T>
std::enable_if<std::is_atomic<T>::value, bool>
foo(T t) { return true; }
template <class T>
std::enable_if<tmp::is_sequence<T>::value, bool>
foo(T t) { return false; }
int main(void){
foo(1); // return true
auto std::vector<int> a{2};
foo(a); // return false
}
Aber wenn ich eine Klasse benutze, um sie zu bündeln, kann sie nicht kompiliert werden:
template <class T>
class test {
public:
std::enable_if<std::is_atomic<T>::value, bool>
foo(T t) { return true; }
std::enable_if<tmp::is_sequence<T>::value, bool>
foo(T t) { return false; }
};
int main(...) {
test<int> obj;
obj.foo(1);
test<std::vector<int>> obj2;
std::vector<int> tmp{2};
obj2.foo(tmp);
}
Klang ++ Druck:
error: functions that differ only in their return type cannot be overloaded
Also schreibe ich etwas, um dem Compiler zu schummeln (fügen Sie ein S in den zweiten Platz hinzu foo
):
template <class S>
std::enable_if<tmp::is_sequence<T>::value, bool>
foo(T t) { return false; }
Es kann immer noch nicht funktionieren:
error: no type named 'type' in 'std::enable_if<false, bool>'
Wie kann ich es in einer Klasse funktionieren lassen?