linux的异常 segv,Unix/Linux C 异常处理的问题

在全局(静态全局)变量的构造和析构期间,每个ANSI C++ 都捕获到异常是不可能的。因此,ANSI C++

不建议在那些其实例可能被定义为全局实例(静态全局实例)的类的构造函数和析构函数中抛出异常。换一种说法就是永远都不要为那些其构造函数和析构函数可能抛出异常的类定义全局(静态全局)实例。不过,如果假定有一个特定编译器和一个特定系统,那么可能可以这样做,幸运的是,对于

Linux 上的 GCC,恰好是这种情况。

使用ExceptionHandler类可以展示这一点,该类也采用了singleton设计模式。其构造函数注册了一个未捕获的处理程序。因为每次只能有一个未捕获的处理程序处理一个活动进程,构造函数应该只被调用一次,因此要采用singleton模式。应该在定义有问题的实际全局(静态全局)变量之前定义ExceptionHandler

的全局(静态全局)实例。

清单 3. 处理构造函数中的异常class ExceptionHandler

{

private:

class

SingleTonHandler

{

public:

SingleTonHandler()

{

set_terminate(Handler);

}

static

void Handler()

{

// Exception from construction/destruction of global

variables

try

{

// re-throw

throw;

}

catch (SegmentationFault

&)

{

cout << "SegmentationFault" << endl;

}

catch

(FloatingPointException &)

{

cout << "FloatingPointException"

<< endl;

}

catch (...)

{

cout << "Unknown Exception"

<< endl;

}

//if this is a thread performing some core

activity

abort();

// else if this is a thread used to service

requests

//

pthread_exit();

}

};

public:

ExceptionHandler()

{

static

SingleTonHandler

s_objHandler;

}

};

//

class

A

{

public:

A()

{

//int i = 0, j = 1/i;

*(int *)0 =

0;

}

};

// Before defining any global variable, we define a dummy

instance

// of ExceptionHandler object to make sure that

//

ExceptionHandler::SingleTonHandler::SingleTonHandler() is

invoked

ExceptionHandler g_objExceptionHandler;

A

g_a;

//

int

main(int argc, char* argv[])

{

return 0;

}

处理多线程程序中的异常

: 网友原创:从N层到.NET详细剖析原理

本文章共:3页

[2]

views:(0) | Comments:(0) | |

相关内容:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值