Heim >Backend-Entwicklung >C++ >Ausnahmebehandlung und Ausnahmespezifizierer für C++-Funktionen

Ausnahmebehandlung und Ausnahmespezifizierer für C++-Funktionen

WBOY
WBOYOriginal
2024-04-12 17:33:02741Durchsuche

Die Ausnahmebehandlung behandelt Laufzeitfehler, einschließlich des Auslösens, Abfangens und Behandelns von Ausnahmen. Ausnahmespezifizierer werden verwendet, um die Arten von Ausnahmen anzugeben, die eine Funktion auslösen kann, einschließlich noexclusive(expr) (gibt an, dass keine Ausnahme ausgelöst werden soll) und throw() (gibt an, dass jede Art von Ausnahme ausgelöst werden kann). Im tatsächlichen Fall verwendet die Funktion print_file den Bezeichner throw() und den Block try-catch, um die Ausnahme std::runtime_error in der Hauptfunktion abzufangen und den Fehler beim Öffnen der Datei zu behandeln.

C++ 函数的异常处理和异常说明符

Ausnahmebehandlung und Ausnahmespezifizierer von C++-Funktionen

Die Ausnahmebehandlung ist der Schlüsselmechanismus für die Behandlung von Laufzeitfehlern. Sie ist in drei Teile unterteilt: Ausnahmen auslösen, Ausnahmen abfangen und Ausnahmen behandeln. In C++ werden Ausnahmen durch Ausnahmeklassen dargestellt.

Eine Ausnahme auslösen

Verwenden Sie das Schlüsselwort throw, um eine Ausnahme auszulösen. Als Ausnahme kann eine Ausnahmeklasse oder ein beliebiges Objekt mit spezifischer Funktionalität dienen. Zum Beispiel: throw 关键字抛出异常。异常类或具有特定功能的任意对象都可以作为异常。例如:

throw std::runtime_error("失败!");

捕获异常

使用 try-catch 块捕获异常。try 块包含可能抛出异常的代码,而 catch 块指定如何处理不同类型的异常。例如:

try {
  // 可能抛出异常的代码
} catch (const std::runtime_error& e) {
  // 处理 std::runtime_error 异常
} catch (const std::exception& e) {
  // 处理所有其他异常
}

异常说明符

异常说明符添加到函数签名中,以指定函数可以抛出的异常类型。有两种异常说明符:

  • noexcept(expr):指定函数不抛出任何异常,其中 expr 为常量表达式。
  • throw():指定函数可以抛出任何类型的异常。

实战案例

考虑一个读取文件并将其打印到控制台的函数。该函数可能会由于文件不存在或访问被拒绝而引发异常。我们可以使用异常说明符和 try-catch 块来处理这些情况。

#include <iostream>
#include <fstream>

void print_file(const std::string& file_name) {
  std::ifstream file(file_name);
  if (!file.is_open()) throw std::runtime_error("无法打开文件!");

  std::string line;
  while (std::getline(file, line)) {
    std::cout << line << std::endl;
  }
}

int main() {
  try {
    print_file("test.txt");
  } catch (const std::runtime_error& e) {
    std::cerr << e.what() << std::endl;
  }

  return 0;
}

在函数 print_file 中,异常说明符 throw() 指定该函数可以抛出任何类型的异常。在 main 函数中,我们使用 try-catch 块来处理异常。如果打开文件时发生错误,则会抛出 std::runtime_errorrrreee

🎜Ausnahmen abfangen🎜🎜🎜Verwenden Sie den try-catch-Block, um Ausnahmen abzufangen. try-Blöcke enthalten Code, der Ausnahmen auslösen kann, während catch-Blöcke angeben, wie mit verschiedenen Arten von Ausnahmen umgegangen werden soll. Zum Beispiel: 🎜rrreee🎜🎜Ausnahmespezifizierer 🎜🎜🎜Ausnahmespezifizierer werden zu Funktionssignaturen hinzugefügt, um die Arten von Ausnahmen anzugeben, die die Funktion auslösen kann. Es gibt zwei Ausnahmespezifizierer: 🎜
  • 🎜noexclusive(expr)🎜: Die angegebene Funktion löst keine Ausnahmen aus, wobei expr ein konstanter Ausdruck ist.
  • 🎜throw()🎜: Die angegebene Funktion kann jede Art von Ausnahme auslösen.
🎜🎜Praktisches Beispiel🎜🎜🎜Stellen Sie sich eine Funktion vor, die eine Datei liest und auf der Konsole ausgibt. Diese Funktion löst möglicherweise eine Ausnahme aus, weil die Datei nicht vorhanden ist oder der Zugriff verweigert wird. Wir können Ausnahmespezifizierer und try-catch-Blöcke verwenden, um diese Situationen zu behandeln. 🎜rrreee🎜In der Funktion print_file gibt der Ausnahmespezifizierer throw() an, dass die Funktion jede Art von Ausnahme auslösen kann. In der Funktion main verwenden wir einen Block try-catch, um Ausnahmen zu behandeln. Wenn beim Öffnen der Datei ein Fehler auftritt, wird eine std::runtime_error-Ausnahme ausgelöst und eine Fehlermeldung an die Konsole ausgegeben. 🎜

Das obige ist der detaillierte Inhalt vonAusnahmebehandlung und Ausnahmespezifizierer für C++-Funktionen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn