《进程通信》PPT课件.ppt
《《进程通信》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《进程通信》PPT课件.ppt(35页珍藏版)》请在三一办公上搜索。
1、1,进程通信(communication,低级通讯-信号机制高级通讯(管道,IPC,Scoket),2,进程间通信的类型,低级通信:只能传递状态和整数值(控制信息),包括进程互斥和同步所采用的信号量和管程机制。优点的速度快。缺点是:传送信息量小:效率低,每次通信传递的信息量固定,若传递较多信息则需要进行多次通信。编程复杂:用户直接实现通信的细节,编程复杂,容易出错。高级通信:能够传送任意数量的数据,包括三类:共享存储区、管道、消息。,返回,1.低级通信和高级通信,3,2.直接通信和间接通信,直接通信:信息直接传递给接收方,如管道。在发送时,指定接收方的地址或标识,也可以指定多个接收方或广播式地
2、址;在接收时,允许接收来自任意发送方的消息,并在读出消息的同时获取发送方的地址。间接通信:借助于收发双方进程之外的共享数据结构作为通信中转,如消息队列。通常收方和发方的数目可以是任意的。,4,3.高级通信的特征,通信链路(communication link):点对点/多点/广播单向/双向有容量(链路带缓冲区)/无容量(发送方和接收方需自备缓冲区)数据格式:字节流(byte stream):各次发送之间的分界,在接收时不被保留,没有格式;报文(datagram/message):各次发送之间的分界,在接收时被保留,通常有格式(如表示类型),定长/不定长报文,可靠报文/不可靠报文。收发操作的同步
3、方式发送阻塞(直到被链路容量或接收方所接受)和不阻塞(失败时立即返回)接收阻塞(直到有数据可读)和不阻塞(无数据时立即返回)由事件驱动收发:在允许发送或有数据可读时,才做发送和接收操作,5,低级通讯-信号机制,一个进程向另一个进程或进程组(或自己)发送(kill系统调用):发送者必须具有接收者同样的有效用户ID,或者发送者是超级用户身份某些键盘按键,如:中断字符(通常是Ctrl+C或Del)、暂停字符(如Ctrl+Z)硬件条件,如:除数为零、浮点运算错、访问非法地址等异常条件软件条件,如:Socket中有加急数据到达,1.信号类型,6,2.对信号的处理,进程可以设置信号处理例程(signal系
4、统调用),在接收到信号时就被调用,称为捕获该信号。信号处理例程的参数是接收到信号的编号。进程也可以忽略指定的信号(SIG_IGN)。只有SIGKILL信号(无条件终止进程)和SIGSTOP(使进程暂停)不能被忽略。在库函数system()的实现中,通过fork和exec加载新程序之后,在父进程中对SIGINT和SIGQUIT都要忽略,然后wait直到子进程终止,才恢复对SIGINT和SIGQUIT的原有处理例程。进程创建后为信号设立了默认处理例程(SIG_DFL),如:终止并留映象文件(core),7,信号的接收Signal(signame,function)function(SIG_DFL,
5、SIG_IGN,user_function)SIG_DFL-系统默认处理方式SIG_IGN-忽略该信号(除SIGSTOP,SIGKILL)User_functiong-按用户指定的处理方式处理,主要针对SIGUSR1,SIGUSR2(16,17号)信号,其它信号如忽略可按此方式处理。,8,信号的发送按约定的事件发送(按键,硬件,函数)通过kill函数直接发送信号给指定的进程。kill(pid,sig)-program kill signame pid-terminal,9,例1#include#include static void sig_usr(int);int main(void)sig
6、nal(SIGUSR1,sig_usr);signal(SIGUSR2,sig_usr);for(;)pause();static void sig_usr(int sign)if(sign=SIGUSR1)printf(receive SIGUS1n);else if(sign=SIGUSR2)printf(receive SIGUS2n);else printf(receive other);return;,a.out&Kill USR1 pidnumKill USR2 pidnum,10,例2#include#include#include void waiting(),stop();i
7、nt wait_mark;main()int p1,p2;signal(SIGINT,SIG_IGN);signal(SIGQUIT,SIG_IGN);while(p1=fork()=-1);if(p10)while(p2=fork()=-1);if(p20)wait_mark=1;signal(SIGINT,stop);waiting();kill(p1,16);kill(p2,17);wait(0);wait(0);printf(parent process is killed!n);exit(0);,11,else wait_mark=1;signal(17,stop);waiting(
8、);printf(child process 2 is killed by parnent!n);exit(0);else wait_mark=1;signal(16,stop);waiting();printf(child 1 is killedn);exit(0);void waiting()while(wait_mark!=0);void stop()wait_mark=0;,12,高级通讯-管道,管道的概念(pipe)管道是UNIX IPC的最老形式,并且所有U N I X系统都提供此种通信机制,管道有两种限制;(1)它们是半双工的。数据只能在一个方向上流动。(2)它们只能在具有公共祖
9、先的进程之间使用。通常,一个管道由一个进程创建,然后该进程调用f o r k,此后父、子进程之间就可应用该管道。实现形式pipe()FIFO,13,通过pipe系统调用创建无名管道,得到两个文件描述符,分别用于写和读。int pipe(int fildes2);文件描述符fildes0为读端,fildes1为写端;通过系统调用write和read进行管道的写和读;进程间双向通信,通常需要两个管道;只适用于父子进程之间或父进程安排的各个子进程之间;UNIX中的命名管道,可通过mknod系统调用建立:指定mode为S_IFIFOint mknod(const char*path,mode_t mo
10、de,dev_t dev);,14,FIFO,F I F O有两种用途:(1)FIFO由s h e l l命令使用以便将数据从一条管道线传送到另一条,为此无需创建中间临时文件。(2)FIFO用于客户机-服务器应用程序中,以在客户机和服务器之间传递数据。,15,#mkfifo myfifo#echo“hello world”myfifo#cat myfifo,16,高级通讯-IPC,共享存储器系统(Shared-Memory System)消息传递系统(Message passing System),17,1 共享存储器系统,共享存储器系统:相互通讯的进程通过共享数据结构和存储区进行通讯,因而可
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 进程通信 进程 通信 PPT 课件
链接地址:https://www.31ppt.com/p-5611273.html