Échec de Static_Assert malgré une fonction de modèle non appelée
En C 0x, les modèles avec des déclarations static_assert inutilisées peuvent entraîner des échecs de compilation. Considérez le code suivant :
template <typename T> inline T getValue(AnObject&) { static_assert(false, "this function has to be implemented for the desired type"); }
Étonnamment, ce code échoue avec l'erreur :
static_assertion failed "this function has to be implemented for the desired type"
Intuitivement, on pourrait s'attendre à ce que le compilateur instancie la fonction modèle uniquement si elle est appelée. Cependant, le standard C précise autrement dans [temp.res]/8 :
Aucun diagnostic ne doit être émis pour une définition de modèle pour laquelle une spécialisation valide peut être générée. Si aucune spécialisation valide ne peut être générée pour une définition de modèle et que ce modèle n'est pas instancié, la définition de modèle est mal formée et aucun diagnostic n'est requis.
Comme il n'existe aucune spécialisation valide qui compile, le compilateur est autorisé de rejeter la définition du modèle qu'il soit instancié ou non.
Pour résoudre ce problème, on peut redéfinir le code comme suit :
template<typename T> struct foobar : std::false_type { }; template <typename T> inline T getValue(AnObject&) { static_assert(foobar<T>::value, "this function has to be implemented for the desired type"); }
Cette modification reporte le diagnostic à l'instanciation du foobar
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!