C++异常处理需用成对的try-catch结构:try块包裹可能抛异常的代码,后接一个或多个catch块捕获对应类型异常,如catch(const std::runtime_error& e)处理运行时错误。

C++ 用 try-catch 块配合 throw 表达式实现异常处理,核心是把错误检测(throw)和错误响应(catch)分离,让程序在出错时能安全跳转到处理逻辑,而不是崩溃或未定义行为。
try-catch 基本结构怎么写?
必须成对使用:try 块包裹可能抛异常的代码,后面紧跟一个或多个 catch 块来捕获对应类型的异常:
try {
// 可能抛异常的操作,比如除零、内存分配失败、自定义检查
if (x == 0) throw std::runtime_error("除数不能为零");
int* p = new int[1000000]; // 可能抛 std::bad_alloc
} catch (const std::runtime_error& e) {
std::cerr << "运行时错误:" << e.what() << '\n';
} catch (const std::bad_alloc& e) {
std::cerr << "内存分配失败:" << e.what() << '\n';
} catch (...) {
std::cerr << "捕获了未知类型的异常\n";
}登录后复制
- 每个
catch按类型匹配,从上到下顺序尝试,只执行第一个匹配的块 - 推荐按引用捕获(
const T&),避免对象切片和不必要的拷贝 -
catch(...)是兜底项,只能放在最后,捕获所有类型(但无法获取异常值)
throw 抛出什么才算“合法”异常?
C++ 允许 throw 任意类型(int、string、自定义类等),但最佳实践是抛出继承自 std::exception 的对象:
- 标准库提供常用异常类:如
std::logic_error(逻辑错误)、std::runtime_error(运行时错误)、std::invalid_argument、std::out_of_range等 - 自定义异常只需继承
std::exception或其子类,并重载what()成员函数返回 C 风格字符串 - 避免抛出裸指针、临时对象地址或局部变量引用——它们在栈展开时已销毁
异常安全的关键细节有哪些?
异常发生时,C++ 会自动执行栈展开(stack unwinding):依次调用当前作用域内已构造对象的析构函数。这是资源管理(如 RAII)起效的基础:
标签: c++
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~