Bestimmen des Ursprungs nicht behandelter Ausnahmen
Bei der Ausnahmebehandlung ist es üblich, Zeilennummern und Quelldateinamen anzugeben, um die Ursache zu ermitteln eine Ausnahme. Wenn Ausnahmen manuell generiert werden, können diese Informationen einfach hinzugefügt werden. Allerdings können nicht behandelte und nicht explizit ausgelöste Ausnahmen eine Herausforderung darstellen.
Verwenden einer benutzerdefinierten Ausnahmeklasse mit Makros
Um diese Einschränkung zu überwinden, besteht eine robustere Lösung darin Verwenden Sie eine benutzerdefinierte Ausnahmeklasse und ein Makro. Der folgende C-Code veranschaulicht, wie dies erreicht werden kann:
#include <iostream> #include <sstream> #include <stdexcept> #include <string> class my_exception : public std::runtime_error { std::string msg; public: my_exception(const std::string &arg, const char *file, int line) : std::runtime_error(arg) { std::ostringstream o; o << file << ":" << line << ": " << arg; msg = o.str(); } ~my_exception() throw() {} const char *what() const throw() { return msg.c_str(); } }; #define throw_line(arg) throw my_exception(arg, __FILE__, __LINE__);
Beispielverwendung
Mit der benutzerdefinierten Ausnahmeklasse und dem Makro können nicht behandelte Ausnahmen erfasst und erfasst werden Ihre Quelle wurde genau bestimmt:
void f() { throw_line("Oh no!"); } int main() { try { f(); } catch (const std::runtime_error &ex) { std::cout << ex.what() << std::endl; } }
Wenn dieser Code ausgeführt wird, wird die folgende Fehlermeldung angezeigt gedruckt:
myFile.cpp:255: Oh no!
Dies identifiziert eindeutig die Datei- und Zeilennummer, in der die Ausnahme ausgelöst wurde, und liefert wertvolle Informationen zum Debuggen und Beheben des Problems.
Das obige ist der detaillierte Inhalt vonWie kann man den Ursprung nicht behandelter Ausnahmen in C ermitteln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!