alarm函数
alarm函数
设置定时器(闹钟)。在指定seconds后,内核会给当前进程发送14)SIGALRM信号。进程收到该信号,默认动作终止。
每个进程都有且只有唯一个定时器。
unsigned int alarm(unsigned int seconds); 返回0或剩余的秒数,无失败。
常用:取消定时器alarm(0),返回旧闹钟余下秒数。
例:alarm(5) → 3sec → alarm(4) → 5sec → alarm(5) → alarm(0)
定时,与进程状态无关(自然定时法)!就绪、运行、挂起(阻塞、暂停)、终止、僵尸...无论进程处于何种状态,alarm都计时。
练习:编写程序,测试你使用的计算机1秒钟能数多少个数。 【alarm .c】
使用time命令查看程序执行的时间。 程序运行的瓶颈在于IO,优化程序,首选优化IO。
实际执行时间 = 系统时间 + 用户时间 + 等待时间
/*** alarm.c ***/ #include<stdio.h> #include<unistd.h> int main() { int i; alarm(1); for(i = 0; ; i++) { printf("%d\n",i); } return 0; }
/*** my_alarm.c ***/ #include<stdio.h> #include<sys/time.h> #include<stdlib.h> #include<unistd.h> /* struct itimerval{ struct timeval { it_value.tv_sec; it_value.tv_usec; }it_interval; struct timerval{ it_value.tv_sec; it_value.tv_usec; }it_value; }it,oldit; */ unsigned int my_alarm(unsigned int sec) { struct itimerval it,oldit; int ret; it.it_value.tv_sec = sec; it.it_value.tv_usec = sec; it.it_interval.tv_sec = sec; it.it_interval.tv_usec = sec; ret = setitimer(ITIMER_REAL,&it,&oldit); if(-1 == ret) { perror("setitimer"); exit(1); } return oldit.it_value.tv_sec; } int main() { int i; my_alarm(1); for(i = 0; ; i++) { printf("i = %d\n",i); } return 0; }
setitimer函数
设置定时器(闹钟)。 可代替alarm函数。精度微秒us,可以实现周期定时。
int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value); 成功:0;失败:-1,设置errno
参数:which:指定定时方式
① 自然定时:ITIMER_REAL → 14)SIGLARM 计算自然时间
② 虚拟空间计时(用户空间):ITIMER_VIRTUAL → 26)SIGVTALRM 只计算进程占用cpu的时间
③ 运行时计时(用户+内核):ITIMER_PROF → 27)SIGPROF 计算占用cpu及执行系统调用的时间
练习: 使用setitimer函数实现alarm函数,重复计算机1秒数数程序。 【setitimer.c】
拓展练习,结合man page编写程序,测试it_interval、it_value这两个参数的作用。 【setitimer1.c】
提示: it_interval:用来设定两次定时任务之间间隔的时间。
it_value:定时的时长
两个参数都设置为0,即清0操作。
raise和abort函数
raise 函数:给当前进程发送指定信号(自己给自己发) raise(signo) == kill(getpid(), signo);
int raise(int sig); 成功:0,失败非0值
abort 函数:给自己发送异常终止信号 6) SIGABRT 信号,终止并产生core文件
void abort(void); 该函数无返回
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)