MISE À JOUR: Depuis C++ 11, utilisez le modèle is_fundamental
de la bibliothèque standard:
#include <type_traits>
template<class T>
void test() {
if (std::is_fundamental<T>::value) {
// ...
} else {
// ...
}
}
// Generic: Not primitive
template<class T>
bool isPrimitiveType() {
return false;
}
// Now, you have to create specializations for **all** primitive types
template<>
bool isPrimitiveType<int>() {
return true;
}
// TODO: bool, double, char, ....
// Usage:
template<class T>
void test() {
if (isPrimitiveType<T>()) {
std::cout << "Primitive" << std::endl;
} else {
std::cout << "Not primitive" << std::endl;
}
}
Afin d'économiser les frais généraux d'appel de fonction, utilisez struct:
template<class T>
struct IsPrimitiveType {
enum { VALUE = 0 };
};
template<>
struct IsPrimitiveType<int> {
enum { VALUE = 1 };
};
// ...
template<class T>
void test() {
if (IsPrimitiveType<T>::VALUE) {
// ...
} else {
// ...
}
}
Comme d'autres l'ont souligné, vous pouvez économiser votre temps Il suffit de mettre cela en œuvre et d'utiliser is_fundamental de la bibliothèque Boost Type Traits, qui semble faire exactement la même chose.
Notez également que l'inverse existe: 'std :: is_class', par ex.https://stackoverflow.com/questions/11287043/is-there-a-way-to-specialize-a-template-to-target-primitives –