Linux环境进程间通信----信号与管道
一、信号:
信号主要用来通知进程异步事件的发生。可以使用“kill -l ”命令来显示系统中的信号。进程可以忽略大部分信号,但是有两个是不能忽略的:
(1)SIGSTOP:这个信号将中断进程的执行。
(2)SIGKILL:这个信号将强制进程退出。
Linux使用了堆栈来管理要执行的信号处理程序,这样当一个信号处理程序完成操作时,下一个将被调用,依次下去。
当进程收到信号后,怎么处理这个信号多半是由收到信号的那个进程自行决定,除非收到的信号是SIGKILL之类只能采取默认行动的信号。Linux处理信号主要有下面4种方式:
(1)采用系统默认的处理方式。一般而言,进程对信号的默认处理方式都是终止运行。
(2)忽略该信号。
(3)暂时搁置该信号。
(4)由程序设计人员利用系统调用signal设定处理信号的函数。以下是一个例子:
/*
* signalHandler.ci
*
* Created on: Aug 4, 2013
* Author: root
*/ #include <stdio.h>
#include <signal.h> void initfunc(int signum);
void exitfunc(int signum); int main(){
char buffer1[], buffer2[];
int i;
if(signal(SIGINT, &initfunc) == -){
printf("Couldn't register signal handler for SIGINT!\n");
exit();
}
if(signal(SIGTSTP, &initfunc) == -){
printf("Couldn't register signal handler for SIGSTP!\n");
exit();
}
if(signal(SIGTERM, &exitfunc) == -){
printf("Couldn't register signal handler for SIGTERM!\n");
exit();
}
printf("Pid of This Process: %d\n", getpid());
for(;;){
printf("Please input:\n");
fgets(buffer1, sizeof(buffer1), stdin);
for(i=;i<;i++){
if(buffer1[i] >= && buffer1[i] <=){
buffer2[i] = buffer1[i]-;
}else{
buffer2[i] = buffer1[i];
}
}
printf("Your input is: %s\n", buffer2);
}
exit();
} void initfunc(int signum){
printf("catch signal %d\n", signum);
}
void exitfunc(int signum){
printf("signal SIGTERM\n");
exit();
}
程序的执行结果如下:
注:在一个终端中执行该程序时,按下Ctrl+Z, 会打印catch signal 20;按下Ctrl+C,会打印catch signal 2;在终端的另一个窗口中输入kill 2457,程序会打印signal SIGTERM,然后退出。
二、管道
管道,就是将一个进程的标准输出和另一个进程的标准输入联系到一起,以供两个进程相互通信的方法。管道是UNIX中最古老的进程通信机制,Linux中也提供了管道。它的应用非常广泛,就连Linux命令行中也有使用,例如:
这条命令中,ls的输出作为sort的输入,sort的输出又作为head -5的输入,head -5的输出将出现在屏幕上。这条命令的最终执行结果是将文件列表排序,但只输出前五行。从中可以直观地看到管道的特点。
Linux环境进程间通信----信号与管道的更多相关文章
- Linux环境进程间通信(一):管道及命名管道
linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...
- <转>Linux环境进程间通信(二): 信号(上)
原文链接:http://www.ibm.com/developerworks/cn/linux/l-ipc/part2/index1.html 原文如下: 一.信号及信号来源 信号本质 信号是在软件层 ...
- Linux环境进程间通信(二): 信号(上)
linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...
- Linux环境进程间通信(二): 信号--转载
http://www.ibm.com/developerworks/cn/linux/l-ipc/part2/index1.html http://www.ibm.com/developerworks ...
- Linux 环境进程间通信(六):
linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...
- Linux环境进程间通信(四):信号灯
linux下进程间通信的几种主要手段: 管道(Pipe)及有名管道(named pipe):管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允 ...
- <转>Linux 环境进程间通信(六)
http://www.ibm.com/developerworks/cn/linux/l-ipc/part6/ 一个套接口可以看作是进程间通信的端点(endpoint),每个套接口的名字都是唯一的(唯 ...
- Linux环境进程间通信: 共享内存
Linux环境进程间通信: 共享内存 第一部分 共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式.两个不同进程A.B共享内存的意思是,同一块物理内存被映射到进程A.B各自的进程地址空间.进 ...
- 《Linux环境进程间通信》系列文章链接
深刻理解 Linux 进程间通信(IPC) http://www.ibm.com/developerworks/cn/linux/l-ipc/index.html Linux 环境进程间通信(一): ...
随机推荐
- 第六周-Scrum Meeting
第一部分ScrumMeeting 每个人的工作: 成员 任务 ISSUE链接 本周已完成的工作 本周计划完成的工作 工作中遇到的困难 李卓峻 负责商品信息页面的界面设计与功能实现 https://gi ...
- mysql性能查看 命中率 慢查询
网上有很多的文章教怎么配置MySQL服务器,但考虑到服务器硬件配置的不同,具体应用的差别,那些文章的做法只能作为初步设置参考,我们需要根据自己的情况进行配置优化,好的做法是MySQL服务器稳定运行了一 ...
- windows环境下安装pymysql(操作带图)
在windows环境下安装pymysql,首先要找到python的安装位置,如果在c盘,启动cmd的时候,要获取管理员权限. 具体步骤,一,管理员模式启动cmd.在箭头指定位置,搜索cmd,出现快捷方 ...
- 漫谈C语言结构体【转】
相信大家对于结构体都不陌生.在此,分享出本人对C语言结构体的学习心得.如果你发现这个总结中有你以前所未掌握的,那本文也算是有点价值了.当然,水平有限,若发现不足之处恳请指出.代码文件test.c我放在 ...
- PAT 1036 Boys vs Girls (25 分)
1036 Boys vs Girls (25 分) This time you are asked to tell the difference between the lowest grade ...
- (59)C# IIS Express 设置
支持非localhost访问 本地测试时 修改 localhost改成127.0.0.1
- Java学习之接口
接口作用:为类提供额外功能(方法) 一.接口定义 interface IDemo { ;//可以简写:int NUM=4; public abstract void show();//可以简写:voi ...
- composer 手动安装及简单使用 windows
1.配置系统变量 Path 计算机->高级系统设置->环境变量->找到系统变量Path 双击 加入 ;php根目录地址:php中ext地址 如 :“;D:\phpStudy ...
- linux replace \r\n to \n
cat test.log | tr -d '\r' | hexdump -C | tail
- Java数据类型简介
Java数据类型 以下两行Java代码定义了两个整数:num1和num2: num1和num2是两个int类型的变量. int关键字指定它的后面是变量的名称,并表示数据类型整数,例如:10,15,70 ...