在 c++++ 中使用自定义异常类可以捕获和处理特定错误。可以通过定义一个派生自 std::exception 的自定义类来创建自定义异常。该类可以包含错误消息等附加信息。通过抛出异常(使用 throw),错误信息会被存储在异常对象中。使用 try-catch 块捕获异常,具体步骤如下:1. 定义一个自定义异常类,从 std::exception 派生,并在构造函数中存储错误消息。2. 使用 throw 关键字抛出异常,并传递错误消息。3. 使用 try-catch 块捕获异常,并根据异常类型处理错误。
使用 C++ 自定义异常类处理函数错误
在 C++ 中,自定义异常类可以让我们捕获和处理特定类型的错误。当发生意外情况时,我们可抛出异常,并将错误信息存储在自定义异常对象中。
自定义异常类
立即学习“C++免费学习笔记(深入)”;
点击下载“修复打印机驱动工具”;
让我们首先定义一个自定义异常类:
class MyException : public std::exception {
public:
explicit MyException(const std::string& msg) : message(msg) {}
virtual const char* what() const noexcept override { return message.c_str(); }
private:
std::string message;
};
此类从 std::exception 派生,并有一个构造函数接受错误消息并将其存储在内部 message 成员变量中。what 方法返回异常消息。
抛出和捕获异常
我们可以通过 throw 关键字抛出异常,如下所示:
if (some_condition) {
throw MyException("Error occurred!");
}
在try-catch 块中捕获异常:
try {
// 代码可能会抛出异常
} catch (MyException& ex) {
std::cout << "Caught MyException: " << ex.what() << "n";
} catch (std::exception& ex) {
std::cout << "Caught std::exception: " << ex.what() << "n";
}
实战案例
考虑以下函数:
int divide(int a, int b) {
if (b == 0) {
// 抛出自定义异常
throw MyException("Division by zero not allowed!");
}
return a / b;
}
此函数在尝试除以 0 时抛出 MyException 异常。让我们在 main 函数中使用它:
int main() {
try {
int result = divide(10, 2);
std::cout << "Result: " << result << "n";
result = divide(10, 0); // 会抛出异常
std::cout << "Result: " << result << "n";
} catch (MyException& ex) {
std::cout << "MyException: " << ex.what() << "n";
} catch (std::exception& ex) {
std::cout << "std::exception: " << ex.what() << "n";
}
return 0;
}
当运行该程序时,它会打印:
Result: 5
MyException: Division by zero not allowed!