C++ SIGTERM在被抓住后没有返回

c++ SIGTERM not returning after caught

本文关键字:返回 SIGTERM C++      更新时间:2023-10-16

我试图在我的程序中捕获SIGTERM,这就是问题所在。

我的程序启动并为信号SIGTERM设置侦听器。然后程序进入一个循环,该循环使用 select 连续检查套接字文件描述符,使其不阻塞。当我通过 kill 发送程序 TERM 时,程序确认它接收到信号,但这就是它不会返回到我之前描述的循环。

信号处理程序在类中设置一个公共变量,以便循环知道退出。我应该提到,在 gdb 中这有效,但在 gdb 之外它不起作用。

提前谢谢。

class A
{
    public:
        bool volatile stop;
    void loop();
    {
        while(!stop)
            {
                //check socket
            }
    }
};
A *aptr;
void sigterm_handler(int i)
{
    aptr->stop = true;
}
int main()
{
    A a;
    aptr = &a;
    struct sigaction sa;
    sa.sa_handler = &sigterm_handler;
    sigaction(SIGTERM, &sa, NULL);
    a.stop = false;
    a.loop();
}

编辑:抱歉没有正确完成代码。

您需要将停止设置为"易失性",否则编译器实际上不会在循环中检查它,因为它认为它无法更改。

bool volatile stop;

也许这与未初始化的其他struct sigaction成员有关。 gdb可能会将内存初始化为 0,而没有 gdb 则不会启动内存。

如上所述,易失性是正确的答案。我还想补充一点,根据您的代码 sigwait() 将是更好的解决方案,而不是循环......顺便说一句,在 sigwait 的情况下,您不需要信号处理程序

哎呀,对不起,错过了套接字操作

您可能会发现任何信号(尤其是 SIGTERM)都会终止您在 while 循环中执行的任何系统调用。我所说的"系统调用"是指从套接字读取、选择或连接套接字的任何内容。

看看这篇文章。

另请查看示例测试程序。