APUE学习笔记——第十章信号中10.15节例程的运行结果与书本里的不一样
1.程序
#include "apue.h"
#include <setjmp.h>
#include <time.h>
static sigjmp_buf jmpbuf;
static volatile sig_atomic_t canjump;
void pr_mask(const char *str)
{
sigset_t sigset;
int errno_save;
errno_save = errno;
if (sigprocmask(0, NULL, &sigset) < 0)
err_sys("sigprocmask error");
printf("%s", str);
if (sigismember(&sigset, SIGINT)) printf("SIGINT");
if (sigismember(&sigset, SIGQUIT)) printf("SIGQUIT");
if (sigismember(&sigset, SIGUSR1)) printf("SIGUSR1");
if (sigismember(&sigset, SIGALRM)) printf("SIGALRM");
printf("\n");
errno = errno_save;
}
static void sig_usr1(int signo)
{
time_t starttime;
if (canjump == 0)
return ;
pr_mask("starting sig_usr1:");
alarm(3);
starttime = time(NULL);
for (;;)
if (time(NULL) > starttime + 5)
break;
pr_mask("finishing sig_usr1:");
canjump = 0;
siglongjmp(jmpbuf, 1);
}
static void sig_alrm(int signo)
{
pr_mask("int sig_alrm: ");
}
int main(void)
{
if (signal(SIGUSR1, sig_usr1) == SIG_ERR)
err_sys("signal(SIGUSR1) error");
if (signal(SIGALRM, sig_alrm) == SIG_ERR)
err_sys("signal(SIGALRM) error");
pr_mask("starting main: ");
if (sigsetjmp(jmpbuf, 1))
{
pr_mask("ending main: ");
exit(0);
}
canjump = 1;
for (;;)
pause();
}
2.结果
xiaoheng@ubuntuxh:~/Program/apue/apue10/1010$ ./1015 &
[1] 18966
xiaoheng@ubuntuxh:~/Program/apue/apue10/1010$ starting main:
kill -USR1 18966
starting sig_usr1:
xiaoheng@ubuntuxh:~/Program/apue/apue10/1010$ int sig_alrm:
finishing sig_usr1:
ending main:
没有打印SIGUSR1跟SIGALRM
转载于:https://www.cnblogs.com/xiaoheng008/p/3735841.html
APUE学习笔记——第十章信号中10.15节例程的运行结果与书本里的不一样相关推荐
- APUE读书笔记-第十章-信号
产生信号的五种方式 用户按某些终端键 硬件异常 进程调用kill函数 用户使用kill命令 检测到某种软件条件已经发生 处理信号的三种方式 忽略(SIGKILL,SIGSTOP不能被忽略) 捕捉(SI ...
- 《Go语言圣经》学习笔记 第十章 包和工具
<Go语言圣经>学习笔记 第十章 包和工具 目录 包简介 导入路径 包声明 导入声明 包的匿名导入 包和命名 工具 注:学习<Go语言圣经>笔记,PDF点击下载,建议看书. G ...
- Go语言开发学习笔记(持续更新中)
Go语言开发学习笔记(持续更新中) 仅供自我学习 更好的文档请选择下方 https://studygolang.com/pkgdoc https://www.topgoer.com/go%E5%9F% ...
- Java快速入门学习笔记3 | Java语言中的表达式与操作符
有人相爱,有人夜里开车看海,有人却连LeetCode第一题都解不出来!虽然之前系统地学习过java课程,但是到现在一年多没有碰过Java的代码,遇到LeetCode不知是喜是悲,思来想去,然后清空自己 ...
- Java快速入门学习笔记2 | Java语言中的基本类型
有人相爱,有人夜里开车看海,有人却连LeetCode第一题都解不出来!虽然之前系统地学习过java课程,但是到现在一年多没有碰过Java的代码,遇到LeetCode不知是喜是悲,思来想去,然后清空自己 ...
- 菜鸟学习笔记:Java提升篇10(网络2——UDP编程、TCPSocket通信、聊天室案例)
菜鸟学习笔记:Java提升篇10(网络2--UDP编程.TCPSocket通信) UDP编程 TCP编程(Socket通信) 单个客户端的连接 多个客户端的连接(聊天室案例) UDP编程 在上一篇中讲 ...
- ROS学习笔记十一:ROS中数据的记录与重放
ROS学习笔记十一:ROS中数据的记录与重放 本节主要介绍如何记录一个正在运行的ROS系统中的数据,然后在一个运行的系统中根据记录文件重新产生和记录时类似的运动情况.本例子还是以小海龟例程为例. 记录 ...
- 【Machine Learning 学习笔记】feature engineering中noisy feature的影响
[Machine Learning 学习笔记]feature engineering中noisy feature的影响 通过本篇博客记录一下添加噪声对Lasso和SVM的影响,采用的数据集为sklea ...
- amazeui学习笔记--css(常用组件10)--导航条Topbar
amazeui学习笔记--css(常用组件10)--导航条Topbar 一.总结 1. 导航条:就是页面最顶端的导航条:在容器上添加 .am-topbar class,然后按照示例组织所需内容.< ...
最新文章
- 数组、ArrayList、链表、LinkedList
- C++编程基础二 04-默认实参
- python绘制好几个子图_python绘制多个子图的实例
- iOS开发之FMDB
- Binding(一):数据绑定
- SQL Server数据库持续集成简介
- 使用 artitalk + LeanCloud 配置给个人博客搭建说说
- Azure China (4) 管理Azure China Storage Account
- Babelua 调试
- AO采集用友oracle,用SQL快速生成用友GRP-U8的AO财务账套的方法2017
- NTFS,FAT32和exFAT文件系统的区别
- 爱五笔iWuBi for Mac(五笔练习工具)
- 【R语言实验】基于R语言的时间序列平稳性检验
- 啊哈添柴挑战1057向世界问好C++
- 力扣707设计链表(单链表,JavaScript)
- Java根据当前日期获取年初,年末,季初,季末,月初,月末日期的方法
- 动手学深度学习番外篇 01.为什么from d2l import torch as d2l
- IQ信号,IQ样本,IQ数据,constallation diagram(星座图)
- Android 动画应用大集合
- 【卸载CUDA-10.0】