[io]进程间通信 -信号函数ALARM:

unsigned int alarm(unsigned int seconds)

头文件:

#include<unistd.h>

功能:

安排内核在指定的秒数后向调用进程发送 SIGALRM 信号

参数:

seconds 指定了从调用时刻开始经过多少秒后触发该信

返回值:

函数的返回值是之前设置的闹钟剩余的秒数,如果没有设置过闹钟,则返回0

注意:

1.一个进程只能有一个闹钟时间。如果在调用alarm时已设置过闹钟时间,则之前的闹钟时间被新值所代替

2.当时间到达设定的秒数时,系统会生成一个 SIGALRM 信号,该信号默认行为是终止进程。

需要注意的是,由于进程调度的延迟,进程实际接收到该信号的时间可能会有延迟。

3.在单线程程序中是允许的,但在多线程程序中并不适用

cs 复制代码
#include<stdio.h>
#include<signal.h>
#include<unistd.h>
int main
{
int n=alarm(3);
printf("first alarm:%d\n",n);
sleep(1);

n=alarm(5);
printf("%d\n",n);
while(1);
return 0;
}
相关推荐
稚辉君.MCA_P8_Java6 小时前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
无限进步_7 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
Swift社区7 小时前
LeetCode 432 - 全 O(1) 的数据结构
数据结构·算法·leetcode
逝玄7 小时前
关于图灵停机问题不可判定性证明
算法·计算机科学
低客的黑调7 小时前
为你的项目选择一个适合的[垃圾收集器]
java·jvm·算法
芬加达7 小时前
leetcode34
java·数据结构·算法
资深web全栈开发8 小时前
LeetCode 1015. 可被 K 整除的最小整数 - 数学推导与鸽巢原理
算法·leetcode·职场和发展
dragoooon348 小时前
[优选算法专题八.分治-归并 ——NO.46~48 归并排序 、数组中的逆序对、计算右侧小于当前元素的个数]
数据结构·算法·排序算法·分治
CoderYanger8 小时前
优选算法-队列+宽搜(BFS):72.二叉树的最大宽度
java·开发语言·算法·leetcode·职场和发展·宽度优先·1024程序员节