通过继承std::exception并重写what()方法可自定义异常信息输出,支持静态消息、使用runtime_error简化实现及动态拼接行号函数名等详细信息,提升错误描述能力与程序可维护性。

在C++中,自定义异常信息输出主要通过继承标准异常类 std::exception 或其派生类(如 std::runtime_error),并重写 what() 方法来实现。这样可以在抛出异常时提供更具描述性的错误信息。
1. 继承 std::exception 并重写 what() 方法
最常见的方式是定义一个类,继承自 std::exception,并在类中实现自己的 what() 函数,该函数返回一个C风格字符串(const char*)。
示例:
#include #include #includeclass MyException : public std::exception {private:std::string msg;public:MyException(const std::string& message) : msg(message) {}
const char* what() const noexcept override { return msg.c_str();}
};
立即学习“C++免费学习笔记(深入)”;
// 使用示例void test() {throw MyException("这是一个自定义异常信息");}
int main() {try {test();} catch (const std::exception& e) {std::cout
输出结果:
捕获异常: 这是一个自定义异常信息
2. 使用 std::runtime_error 等标准异常类(推荐简单场景)
如果不需要复杂的逻辑,可以直接使用 std::runtime_error,它接受字符串作为构造参数,并自动提供 what() 的实现。
示例:
#include #includevoid risky_function() {throw std::runtime_error("文件打开失败");}
int main() {try {risky_function();} catch (const std::exception& e) {std::cout << "错误: " << e.what() << std::endl;}return 0;}
3. 支持动态信息拼接的自定义异常
有时需要根据运行时数据生成异常信息,比如包含行号、函数名或变量值。可以通过构造函数传参并格式化字符串实现。
示例:带行号和消息的异常
#include #include #includeclass DetailedException : public std::exception {private:std::string info;public:DetailedException(const std::string& msg, int line, const std::string& func){std::ostringstream oss;oss << "[" << func << ": " << line << "] " << msg;info = oss.str();}
const char* what() const noexcept override { return info.c_str();}
};
立即学习“C++免费学习笔记(深入)”;
// 宏简化使用
define THROW_DETAILED(msg)
throw DetailedException(msg, __LINE__, __func__)
void problematic() {THROW_DETAILED("数值超出范围");}
int main() {try {problematic();} catch (const std::exception& e) {std::cout
输出可能为:
详细错误: [problematic: 38] 数值超出范围
基本上就这些。通过继承和重写 what(),你可以灵活控制异常信息的生成和输出,既满足调试需求,也提升程序的可维护性。
以上就是C++如何实现自定义异常信息输出的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1474730.html
微信扫一扫
支付宝扫一扫