Linux 下 C 程序的异常处理技巧.doc_第1页
Linux 下 C 程序的异常处理技巧.doc_第2页
Linux 下 C 程序的异常处理技巧.doc_第3页
Linux 下 C 程序的异常处理技巧.doc_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

linux 下 c+程序的异常处理技巧处理 c+ 中的异常会在语言级别上遇到少许隐含限制,但在某些情况下,您可以绕过它们。学习各种利用异常的方法,您就可以生产更可靠的应用程序。 保留异常来源信息在 c+中,无论何时在处理程序内捕获一个异常,关于该异常来源的信息都是不为人知的。异常的具体来源可以提供许多更好地处理该异常的重要信息,或者提供一些可以附加到错误日志的信息,以便以后进行分析。 为了解决这一问题,可以在抛出异常语句期间,在异常对象的构造函数中生成一个堆栈跟踪。exceptiontracer 是示范这种行为的一个类。 清单 1. 在异常对象构造函数中生成一个堆栈跟踪/ sample program:/ 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;free(symbols);管理信号每当进程执行一个令人讨厌的动作,以致于 linux? 内核发出一个信号时,该信号都必须被处理。信号处理程序通常会释放一些重要资源并终止应用程序。在这种情况下,堆栈上的所有对象实例都处于未破坏状态。另一方面,如果这些信号被转换成 c+ 异常,那么您可以优雅地调用其构造函数,并安排多层 catch 块,以便更好地处理这些信号。 清单 2 中定义的 signalexceptionclass,提供了表示内核可能发出信号的 c+ 异常的抽象。signaltranslator 是一个基于 signalexceptionclass 的模板类,它通常用来实现到 c+ 异常的转换。在任何瞬间,只能有一个信号处理程序处理一个活动进程的一个信号。因此,signaltranslator 采用了 singleton 设计模式。整体概念通过用于 sigsegv 的 segmentationfault 类和用于 sigfpe 的 floatingpointexception 类得到了展示。 清单 2. 将信号转换成异常template class signaltranslatorprivate:class singletontranslatorpublic:singletontranslator()signal(signalexceptionclass:getsignalnumber(), 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;signaltranslator g_objsegmentationfaulttranslator;/ an example for sigfpeclass floatingpointexception : public exceptiontracer, public exceptionpublic:static int getsignalnumber() return sigfpe;signaltranslator g_objfloatingpointexceptiontranslator;管理构造函数和析构函数中的异常在全局(静态全局)变量的构造和析构期间,每个 ansi c+ 都捕获到异常是不可能的。因此,ansi c+ 不建议在那些其实例可能被定义为全局实例(静态全局实例)的类的构造函数和析构函数中抛出异常。换一种说法就是永远都不要为那些其构造函数和析构函数可能抛出异常的类定义全局(静态全局)实例。不过,如果假定有一个特定编译器和一个特定系统,那么可能可以这样做,幸运的是,对于 linux 上的 gcc,恰好是这种情况。 使用 exceptionhandler 类可以展示这一点,该类也采用了 singleton 设计模式。其构造函数注册了一个未捕获的处理程序。因为每次只能有一个未捕获的处理程序处理一个活

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论