您的位置:首页 >C++在Linux中的信号处理方法
发布于2026-04-24 阅读(0)
扫一扫,手机访问
信号,本质上是一种软件中断。它就像系统发给进程的一个即时通知,告诉你某个特定事件发生了。举个最常见的例子:当你在终端里运行程序时按下 Ctrl+C,操作系统就会向你的进程发送一个 SIGINT 信号,意思是“用户想中断你了”。

那么,在C++里我们怎么“接住”并处理这些信号呢?主要有两种经典方法:一种是使用相对简单的 signal 函数,另一种则是功能更强大、控制更精细的 sigaction 函数。下面我们通过两个简单的例子来感受一下。
signal 函数#include
#include
// 信号处理函数
void signal_handler(int signum) {
std::cout << "接收到信号: " << signum << std::endl;
}
int main() {
// 设置信号处理函数
std::signal(SIGINT, signal_handler);
std::cout << "按Ctrl+C发送SIGINT信号..." << std::endl;
// 主循环,等待信号
while (true) {
// ...
}
return 0;
}
sigaction 函数#include
#include
// 信号处理函数
void signal_handler(int signum) {
std::cout << "接收到信号: " << signum << std::endl;
}
int main() {
struct sigaction sa;
sa.sa_handler = signal_handler;
sigemptyset(&sa.sa_mask);
sa.sa_flags = 0;
// 设置信号处理函数
if (sigaction(SIGINT, &sa, NULL) == -1) {
perror("sigaction");
return 1;
}
std::cout << "按Ctrl+C发送SIGINT信号..." << std::endl;
// 主循环,等待信号
while (true) {
// ...
}
return 0;
}
上面两个示例的核心逻辑是一致的:我们都注册了一个名为 signal_handler 的函数来处理 SIGINT 信号。一旦用户按下 Ctrl+C,程序就会捕捉到这个信号,并执行我们预设的处理逻辑——在这里是打印一条接收信息。
不过,这里有个非常重要的原则需要牢记:信号处理函数的设计务必保持简单。尽量避免在里面执行复杂的操作,比如文件I/O、动态内存分配或者调用非异步信号安全的库函数。为什么呢?因为信号可能在任何时间点、打断任何正在执行的代码而触发。如果处理函数太复杂,很容易引发竞态条件甚至死锁。
一个常见的稳健做法是:在信号处理函数里只设置一个简单的标志变量(例如一个全局的 volatile sig_atomic_t 类型变量),记录下“信号已发生”这个事实。然后,在主程序的正常逻辑循环里,再去检查这个标志,并执行那些相对复杂、耗时的实际处理工作。这样就把异步中断和同步处理解耦开了,程序会稳定得多。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9