Gestion des exceptions non interceptées et inattendues (C++)

De RAD Studio
Aller à : navigation, rechercher

Remonter à Gestion des exceptions C++ standard

Si une exception est déclenchée et qu'aucun gestionnaire d'exception n'est trouvé (c'est-à-dire que l'exception n'est pas interceptée), le programme appelle une fonction de terminaison. Vous pouvez spécifier votre propre fonction de terminaison avec set_terminate. Si vous ne spécifiez aucune fonction de terminaison, la fonction terminate est appelée. Par exemple, le code suivant utilise la fonction my_terminate pour gérer les exceptions qui ne sont pas interceptées par un gestionnaire.

 void SetFieldValue(DF *dataField, int userValue) {
 	if ((userValue < 0) || (userValue) > 10))
 		throw EIntegerRange(0, 10, userValue);
 	// ...
 }
 
 void my_terminate() {
 	printf("Exception not caught");
 	abort();
 }
 
 // Set my_terminate() as the termination function
 set_terminate(my_terminate);
 
 // Call SetFieldValue. This generates an exception because the user value is greater
 // than 10. Because the call is not in a try block, my_terminate is called.
 SetFieldValue(DF, 11);

Si une fonction spécifie les exceptions qu'elle déclenche, puis déclenche une exception non spécifiée, une fonction inattendue est appelée. Vous pouvez spécifier votre propre fonction inattendue avec set_unexpected. Si vous ne spécifiez aucune fonction inattendue, la fonction unexpected est appelée.

Voir aussi