linux下捕获Ctrl+C消息

本文介绍了一种方法来捕获程序通过Ctrl+C强制结束时的时间,从而准确计算程序耗时,包括正常结束和异常结束两种情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

     最近在做一个统计程序用时的程序,最简单的是刚开的时间记下来,最后的时间记下来,二者做差就ok了,但是最后同事提醒,如果程序异常结束,比如,用Ctrl+C强制结束,前边方法就没有效果了。于是,在程序中捕获Ctrl+C消息,记录此时时间,与刚开始时间做差,获得Ctrl+C异常终止时程序耗时。

#include <iostream>
#include <time.h>
#include <signal.h>
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>


using namespace std;

clock_t start,finish;   //记录开始时间和结束时时间
void ctrlc_message(int s) //ctrl+c消息捕获函数
{
printf("caught signal %d\n",s);
finish = clock();
double duration = finish - start;
cout<<duration<<" ms"<<endl;
exit(1);
}


int main(int argc, char* argv[])
{
  struct sigaction sigIntHandler;
sigIntHandler.sa_handler = ctrlc_message;
sigemptyset(&sigIntHandler.sa_mask);
sigIntHandler.sa_flags = 0;
sigaction(SIGINT,&sigIntHandler,NULL);

int  duration;
start = clock();

int iss=100000;
while(iss>0)
{
iss--;
cout<<"while"<<endl;
}

finish = clock();
duration = finish - start; //正常结束时程序耗时
cout<<duration<<" ms"<<endl;

return 0;
}
    

<think>我们正在讨论Linux环境中Ctrl+C无法终止程序的情况。这通常发生在程序捕获了SIGINT信号或程序处于非中断状态(如内核态阻塞)。以下将分析原因并提供解决方案。</think>### LinuxCtrl+C 无法终止程序的原因及解决方法 当在 Linux 终端中按 **Ctrl+C** 无法终止程序时,通常是由于以下原因导致: --- #### **核心原因分析** 1. **信号处理被屏蔽** - 程序内部捕获了 `SIGINT` 信号(Ctrl+C 的默认信号)并忽略或自定义处理 - 常见于 Python 脚本(如 `try/except KeyboardInterrupt` 未正确实现)或 C/C++ 程序(`signal(SIGINT, SIG_IGN)`) 2. **程序状态异常** - 进程处于 **不可中断睡眠状态**(D 状态),通常由 I/O 阻塞(如 NFS 挂载失败)或内核操作引起 - 使用 `ps aux` 查看进程状态列(D 状态无法被信号终止) 3. **终端会话异常** - 程序运行在后台作业(如 `command &`)未正确处理信号 - 终端驱动层问题(如伪终端 PTY 配置错误) --- #### **强制终止方案** 1. **尝试其他终止信号** - **Ctrl+\**:发送 `SIGQUIT` 信号(产生 core dump) - **Ctrl+Z**:挂起到后台,再用 `kill -9 %1` 强杀 ```bash # 挂起程序 ^Z [1]+ Stopped program_name # 强杀后台作业 kill -9 %1 ``` 2. **直接使用 kill 命令** - 查找进程 ID 并发送 `SIGKILL`(不可屏蔽): ```bash ps aux | grep program_name # 获取 PID kill -9 PID # 强制终止 ``` 3. **处理 D 状态进程** - 重启相关服务或内核模块(如 NFS 客户端): ```bash sudo systemctl restart nfs-common ``` - 若由内核 bug 引起,需更新内核版本 4. **终端重置** 输入 `reset` 或 `stty sane` 恢复终端设置 --- #### **预防措施** | **场景** | **解决方案** | |------------------------|----------------------------------| | Python 脚本 | 正确实现 `KeyboardInterrupt` 异常处理 | | C/C++ 程序 | 避免屏蔽 `SIGINT` 信号 | | 关键后台进程 | 使用 `nohup` 或 `systemd` 托管 | | 文件系统操作 | 增加 I/O 超时机制 | > ⚠️ **注意**:`kill -9` 是最后手段,可能导致资源未释放。优先尝试 `kill -15`(SIGTERM)正常终止。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值