Linux 下 C程序的异常处理技巧.doc

上传人:laozhun 文档编号:2385061 上传时间:2023-02-17 格式:DOC 页数:5 大小:15KB
返回 下载 相关 举报
Linux 下 C程序的异常处理技巧.doc_第1页
第1页 / 共5页
Linux 下 C程序的异常处理技巧.doc_第2页
第2页 / 共5页
Linux 下 C程序的异常处理技巧.doc_第3页
第3页 / 共5页
Linux 下 C程序的异常处理技巧.doc_第4页
第4页 / 共5页
Linux 下 C程序的异常处理技巧.doc_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《Linux 下 C程序的异常处理技巧.doc》由会员分享,可在线阅读,更多相关《Linux 下 C程序的异常处理技巧.doc(5页珍藏版)》请在三一办公上搜索。

1、Linux 下 C+程序的异常处理技巧处理 C+ 中的异常会在语言级别上遇到少许隐含限制,但在某些情况下,您可以绕过它们。学习各种利用异常的方法,您就可以生产更可靠的应用程序。 保留异常来源信息在 C+中,无论何时在处理程序内捕获一个异常,关于该异常来源的信息都是不为人知的。异常的具体来源可以提供许多更好地处理该异常的重要信息,或者提供一些可以附加到错误日志的信息,以便以后进行分析。 为了解决这一问题,可以在抛出异常语句期间,在异常对象的构造函数中生成一个堆栈跟踪。ExceptionTracer 是示范这种行为的一个类。 清单 1. 在异常对象构造函数中生成一个堆栈跟踪/ Sample Pro

2、gram:/ Compiler: gcc 3.2.3 20030502/ Linux: Red Hat#include #include #include #include using namespace std;/class ExceptionTracerpublic:ExceptionTracer()void * array25;int nSize = backtrace(array, 25);char * symbols = backtrace_symbols(array, nSize);for (int i = 0; i nSize; i+)cout symbolsi endl;fre

3、e(symbols);管理信号每当进程执行一个令人讨厌的动作,以致于 Linux? 内核发出一个信号时,该信号都必须被处理。信号处理程序通常会释放一些重要资源并终止应用程序。在这种情况下,堆栈上的所有对象实例都处于未破坏状态。另一方面,如果这些信号被转换成 C+ 异常,那么您可以优雅地调用其构造函数,并安排多层 catch 块,以便更好地处理这些信号。 清单 2 中定义的 SignalExceptionClass,提供了表示内核可能发出信号的 C+ 异常的抽象。SignalTranslator 是一个基于 SignalExceptionClass 的模板类,它通常用来实现到 C+ 异常的转换。

4、在任何瞬间,只能有一个信号处理程序处理一个活动进程的一个信号。因此,SignalTranslator 采用了 singleton 设计模式。整体概念通过用于 SIGSEGV 的 SegmentationFault 类和用于 SIGFPE 的 FloatingPointException 类得到了展示。 清单 2. 将信号转换成异常template class SignalTranslatorprivate:class SingleTonTranslatorpublic:SingleTonTranslator()signal(SignalExceptionClass:GetSignalNumbe

5、r(), SignalHandler);static void SignalHandler(int)throw SignalExceptionClass();public:SignalTranslator()static SingleTonTranslator s_objTranslator;/ An example for SIGSEGVclass SegmentationFault : public ExceptionTracer, public exceptionpublic:static int GetSignalNumber() return SIGSEGV;SignalTransl

6、ator g_objSegmentationFaultTranslator;/ An example for SIGFPEclass FloatingPointException : public ExceptionTracer, public exceptionpublic:static int GetSignalNumber() return SIGFPE;SignalTranslator g_objFloatingPointExceptionTranslator;管理构造函数和析构函数中的异常在全局(静态全局)变量的构造和析构期间,每个 ANSI C+ 都捕获到异常是不可能的。因此,AN

7、SI C+ 不建议在那些其实例可能被定义为全局实例(静态全局实例)的类的构造函数和析构函数中抛出异常。换一种说法就是永远都不要为那些其构造函数和析构函数可能抛出异常的类定义全局(静态全局)实例。不过,如果假定有一个特定编译器和一个特定系统,那么可能可以这样做,幸运的是,对于 Linux 上的 GCC,恰好是这种情况。 使用 ExceptionHandler 类可以展示这一点,该类也采用了 singleton 设计模式。其构造函数注册了一个未捕获的处理程序。因为每次只能有一个未捕获的处理程序处理一个活动进程,构造函数应该只被调用一次,因此要采用 singleton 模式。应该在定义有问题的实际全局(静态全局)变量之前定义 ExceptionHandler 的全局(静态全局)实例。 清单 3. 处理构造函数中的异常

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号