是信号处理程序,旨在无限期运行
Are signal handlers meant to run indefinitely?
#include <iostream>
#include <csignal>
void handler(int signo){
std::cout << "Caught " << (signo == SIGINT) << std::endl;
}
int main(){
signal(SIGINT, handler);
while(true) ;
}
在Windows和Linux上,当我按 cntrl c 多个次时,这些似乎做了两件不同的事情。在Linux上,我将看到多次捕获的消息,而在Windows上,我会看到一次捕获的消息,然后在第二次出版的 cntrl C 我的程序将关闭。那么,处理程序是否只想捕获一次信号,或无限期地捕获信号?还是我缺少的Windows的属性导致该程序在第二次按下关闭?
据我所知, cntrl c 被视为窗口上的sigint,就像它在linux上一样。
它取决于signal
的实现,这可能等同于sigaction
使用SA_RESETHAND
标志设置或清除 - 要么可以接受POSIX和C标准。
如果要控制此行为,则需要使用sigaction
而不是signal
来设置信号处理程序并设置标志以获取所需的行为。
相关文章:
- 运行同一解决方案的另一个项目的项目
- CMake-按正确顺序将项目与C运行时对象文件链接
- 如何运行位于boost/libs/python/example/tutorial目录中的hello.cpp和Jamfil
- 代码在main()中运行,但在函数中出现错误
- 我在c++代码中生成了一个运行时#3异常
- 如何在linux终端中同时编译和运行c++代码
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 如何在运行中期切换GTK CSS style_context
- 如何在MS Visual Studio 2019中运行QT UI
- 如何通过cpp程序运行shell脚本
- IPC使用多个管道和分支进程来运行Python程序
- 删除指向指针的指针是运行时错误吗
- 如何用参数值调用函数(仅在运行时已知)
- 为什么即使使用-cudart-static进行编译,库用户仍然需要链接到cuda运行时
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- c++中的指针和运行时错误
- 在C应用程序中运行C++(带有STL)函数
- 运行程序时出现问题
- 是信号处理程序,旨在无限期运行
- 运行单元测试似乎会无限期地阻塞io_service