0

我想知道是否有任何简单的方法可以销毁在main()应用程序刚刚崩溃(或被中断或其他原因)之后创建的对象。请参阅代码:

#include <iostream>
#include <signal.h>
#include <stdlib.h>

class TestClass {
public:
    TestClass() { std::cerr << "Constructor" << std::endl; }
    ~TestClass() { std::cerr << "Destructor" << std::endl; }
};

void signal_handler(int signum) {
    std::cerr << "Signal caught " << signum << std::endl;
    exit(1);
}

int main() {

    TestClass a; 

    struct sigaction new_action, old_action;
    new_action.sa_handler = signal_handler;
    sigemptyset (&new_action.sa_mask);
    new_action.sa_flags = 0;

    sigaction (SIGSEGV, NULL, &old_action);
    if (old_action.sa_handler != SIG_IGN)
    {
        sigaction (SIGSEGV, &new_action, NULL);
    }
    // CRASH !!!
    int* p = 0; *p = 0;
}

所以,我安装了一个信号处理程序,它在执行时会进行一些清理,然后退出。显然,这是一个很大的应用程序,所以我想调用创建临时文件的类的析构函数(理论上)。

动态分配它并在signal_handler刚刚释放它时很容易(为了调用析构函数),但这涉及一些额外的工作。

而且,它可能是一个全局对象,但我想避免全局初始化顺序问题......

4

1 回答 1

1

您可以尝试在 SIGSEGV 上安排有序关闭。它并非没有陷阱,但从这里开始: 是否可以在接收到 SIGSEGV 时仅终止一个线程?

您可以尝试终止信号处理程序中的一个有问题的线程,并设置一个全局标志来表示“我们搞砸了,是时候关闭了”。然后在您的主消息循环中,检查标志并在设置时中断。

于 2014-09-04T12:13:46.070 回答