《进程通信》PPT课件

上传人:新** 文档编号:570351779 上传时间:2024-08-03 格式:PPT 页数:35 大小:275.42KB
返回 下载 相关 举报
《进程通信》PPT课件_第1页
第1页 / 共35页
《进程通信》PPT课件_第2页
第2页 / 共35页
《进程通信》PPT课件_第3页
第3页 / 共35页
《进程通信》PPT课件_第4页
第4页 / 共35页
《进程通信》PPT课件_第5页
第5页 / 共35页
点击查看更多>>
资源描述

《《进程通信》PPT课件》由会员分享,可在线阅读,更多相关《《进程通信》PPT课件(35页珍藏版)》请在金锄头文库上搜索。

1、 进程通信(communication低级通讯-信号机制高级通讯(管道, IPC,Scoket)1通讯进程间通信的类型低级通信:只能传递状态和整数值(控制信息),包括进程互斥和同步所采用的信号量和管程机制。优点的速度快。缺点是:n传送信息量小:效率低,每次通信传递的信息量固定,若传递较多信息则需要进行多次通信。n编程复杂:用户直接实现通信的细节,编程复杂,容易出错。高级通信:能够传送任意数量的数据,包括三类:共享存储区、管道、消息。返回1. 低级通信和高级通信2通讯2. 直接通信和间接通信直接通信:信息直接传递给接收方,如管道。n在发送时,指定接收方的地址或标识,也可以指定多个接收方或广播式地

2、址;n在接收时,允许接收来自任意发送方的消息,并在读出消息的同时获取发送方的地址。间接通信:借助于收发双方进程之外的共享数据结构作为通信中转,如消息队列。通常收方和发方的数目可以是任意的。3通讯3. 高级通信的特征通信链路(communication link):n点对点/多点/广播n单向/双向n有容量(链路带缓冲区)/无容量(发送方和接收方需自备缓冲区)数据格式:n字节流(byte stream):各次发送之间的分界,在接收时不被保留,没有格式;n报文(datagram/message):各次发送之间的分界,在接收时被保留,通常有格式(如表示类型),定长/不定长报文,可靠报文/不可靠报文。收

3、发操作的同步方式n发送阻塞(直到被链路容量或接收方所接受)和不阻塞(失败时立即返回)n接收阻塞(直到有数据可读)和不阻塞(无数据时立即返回)n由事件驱动收发:在允许发送或有数据可读时,才做发送和接收操作4通讯低级通讯-信号机制一个进程向另一个进程或进程组(或自己)发送(kill系统调用):发送者必须具有接收者同样的有效用户ID,或者发送者是超级用户身份某些键盘按键,如:中断字符(通常是Ctrl+C或Del)、暂停字符(如Ctrl+Z)硬件条件,如:除数为零、浮点运算错、访问非法地址等异常条件软件条件,如:Socket中有加急数据到达1. 信号类型5通讯2. 对信号的处理进程可以设置信号处理例程

4、(signal系统调用),在接收到信号时就被调用,称为捕获该信号。信号处理例程的参数是接收到信号的编号。进程也可以忽略指定的信号(SIG_IGN)。n只有SIGKILL信号(无条件终止进程)和SIGSTOP(使进程暂停)不能被忽略。n在库函数system()的实现中,通过fork和exec加载新程序之后,在父进程中对SIGINT和SIGQUIT都要忽略,然后wait直到子进程终止,才恢复对SIGINT和SIGQUIT的原有处理例程。进程创建后为信号设立了默认处理例程(SIG_DFL),如:终止并留映象文件(core)6通讯信号的接收Signal(signame,function) functi

5、on( SIG_DFL,SIG_IGN,user_function) SIG_DFL-系统默认处理方式SIG_IGN-忽略该信号(除SIGSTOP,SIGKILL)User_functiong-按用户指定的处理方式处理,主要针对SIGUSR1,SIGUSR2(16,17号)信号,其它信号如忽略可按此方式处理。7通讯信号的发送n按约定的事件发送(按键,硬件,函数)n通过kill函数直接发送信号给指定的进程。 kill(pid,sig)-program kill signame pid-terminal8通讯例1 #include #include static void sig_usr(int)

6、;int main(void)signal(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 pidnum9通讯例2#include #include #inclu

7、de void waiting(),stop(); int 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); 1

8、0通讯else wait_mark=1; signal(17,stop); waiting(); 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; 11通讯高级通讯-管道管道的概念(pipe)管道是UNIX IPC的最老形式,并且所有U N I X

9、系统都提供此种通信机制,管道有两种限制;(1) 它们是半双工的。数据只能在一个方向上流动。(2) 它们只能在具有公共祖先的进程之间使用。通常,一个管道由一个进程创建,然后该进程调用f o r k,此后父、子进程之间就可应用该管道。实现形式npipe()nFIFO12通讯通过pipe系统调用创建无名管道,得到两个文件描述符,分别用于写和读。nint pipe(int fildes2);n文件描述符fildes0为读端,fildes1为写端;n通过系统调用write和read进行管道的写和读;n进程间双向通信,通常需要两个管道;n只适用于父子进程之间或父进程安排的各个子进程之间;UNIX中的命名管

10、道,可通过mknod系统调用建立:指定mode为S_IFIFOnint mknod(const char *path, mode_t mode, dev_t dev);13通讯FIFOF I F O有两种用途:有两种用途:(1) FIFO由由s h e l l命令使用以便将数据从一命令使用以便将数据从一条管道线传送到另一条,为此无需创建中间条管道线传送到另一条,为此无需创建中间临时文件。临时文件。(2) FIFO用于客户机用于客户机-服务器应用程序中,以服务器应用程序中,以在客户机和服务器之间传递数据。在客户机和服务器之间传递数据。14通讯# mkfifo myfifo# echo “hell

11、o world” myfifo# cat myfifo15通讯高级通讯-IPC共享存储器系统(Shared-Memory System) 消息传递系统(Message passing System)16通讯1 共享存储器系统 共享存储器系统共享存储器系统:相互通讯的进程通过:相互通讯的进程通过共享数据共享数据结构结构和和存储区存储区进行通讯,因而可进一步分为:进行通讯,因而可进一步分为: 基于共享数据结构的通讯方式基于共享数据结构的通讯方式;(低效,只适;(低效,只适于传递少量数据)于传递少量数据) 基于共享存储区的通讯方式基于共享存储区的通讯方式。为了传送大量数为了传送大量数据,在存储区中划

12、出一块共享存储区,诸进程可据,在存储区中划出一块共享存储区,诸进程可通过对共享存储区进行读或写数据实现通讯。通过对共享存储区进行读或写数据实现通讯。 1向系统申请共享存储区中的一个分区2指定该分区的关键字3如果已经给其他进程分配了这样的存储区, 将使用分区的描述符返回给申请者4 申请者将申请到的共享分区挂到本进程上返回17通讯共享存储器系统操作创建或打开共享存储区(shmget):依据用户给出的整数值key,创建新区或打开现有区,返回一个共享存储区ID。连接共享存储区(shmat):连接共享存储区到本进程的地址空间,可以指定虚拟地址或由系统分配,返回共享存储区首地址。父进程已连接的共享存储区可

13、被fork创建的子进程继承。拆除共享存储区连接(shmdt):拆除共享存储区与本进程地址空间的连接。共享存储区控制(shmctl):对共享存储区进行控制。如:共享存储区的删除需要显式调用shmctl(shmid, IPC_RMID, 0);18通讯#include #include #include #include #define SHMSZ 27int main(void) char c; int shmid; key_t key; char * shm,*s; /*create a share_memory named 5678*/ key=5678; if(shmid=shmget(k

14、ey,SHMSZ,IPC_CREAT|0666)0) exit(0);/* connecting this share_memory to process */ if (shm=shmat(shmid,NULL,0)=NULL) exit(0);Shm_1.c19通讯/* writting some letters to this memory for other process */ s=shm; for(c=a;c=z;c+) *s+=c; *s=#;/* waitting for another process change this memory */ while( *shm !=*)

15、 sleep(1); exit(0);20通讯#include #include #include #include #define SHMSZ 27int main(void) int shmid; key_t key; char *shm,*s; key=5678; if (shmid=shmget(key,SHMSZ,0666)0) exit(0);Shm_2.c21通讯 if (shm=shmat(shmid,NULL,0)=(char*)-1) exit(0); for(s=shm;*s!=#;s+) putchar(*s); putchar(n); *shm=*; exit(0);

16、22通讯2 消息队列消息队列(message queue):每个message不定长,由类型(type)和正文(text)组成UNIX消息队列API:nmsgget依据用户给出的整数值key,创建新消息队列或打开现有消息队列,返回一个消息队列ID;nmsgsnd发送消息;nmsgrcv接收消息,可以指定消息类型;没有消息时,返回-1;nmsgctl对消息队列进行控制,如删除消息队列;通过指定多种消息类型,可以在一个消息队列中建立多个虚拟信道注意:消息队列不随创建它的进程的终止而自动撤销,必须用msgctl(msgqid, IPC_RMID, 0)。另外,msgget获得消息队列ID之后,for

17、k创建子进程,在子进程中能否继承该消息队列ID而不必再一次msgget。23通讯例 msg_server.c msg_client.c24通讯套接字(socket)双向的,数据格式为字节流(一对一)或报文(多对一,一对多);主要用于网络通信;支持client-server模式和peer-to-peer模式,本机或网络中的两个或多个进程进行交互。提供TCP/IP协议支持UNIX套接字(基于TCP/IP或UNIX域):返回25通讯套接字函数1创建套接字 #include Int socket(int domain,int type,int protocol)n注:domain(AF_UNIX,AF

18、_INET)type(SOCK_STREAM(流),SOCK_DRAM(数据报)Protocol(0-UNIX域,TCP-STREAM,UDPDGRAM) 26通讯套接字函数2关闭套接字 #include n int close(int socket)n int shutdown(int socket,int how) 注:how: SHUT_RD停止从此套接字接收数据,拒绝进一步到达的数据 SHUT_WR -停止从该套接字发送数据。 SHUT_RDWR-停止从该套接字接收和发送数据27通讯重要的结构 #include Struct in_addr in_addr_t s_addr in_ad

19、dr_t : unsigned long int#include struct hostent char *h_name; char *h_aliases; int h_addrtype/* AF_INET*/ int h_length char *h_addr_list /* 主机的IP地址*/ 28通讯IP地址转化函数#include 数点IP地址转整数IP in_addr_t inet_addr(const char *cp) 整数IP地址转数点IP char *inet_ntoa(struct in_addr in)29通讯获取主机的信息函数#include struct hosten

20、t *gethostbyname(char *name) struct hostent *gethostbyaddr(void *addr size_t length, int type) 对于internet地址: type-AF_INET, length 字节长度 name 获取本机信息可通过下面函数 #include int gethostname(char *name, size_t length)30通讯重要的结构#include Struct sockaddr_un sa_family_t sun_family; -AF_UNIX char sun_path#include str

21、uct sockaddr_in sa_family_t sin_family;-AF_INET in_port_t sin_port; struct in_addr sin_addr; unsigned char sin_zero8 /*保留 31通讯流套接字工作图Socket()bind()listen()accept()阻阻塞塞直直到到收收到到客客户户的数据报的数据报read()write()close()Socket()connect()write()read()write()close()服务服务客户客户32通讯套接字操作函数#include 1. int bind(int socke

22、t,struct sockaddr *address, socklen_t address_len) 调用成功返回0,否则返回-1 并置errno struct sockaddr * scokaddr_un 或 sockaddr_in2. Int connect(int socket,struct sockaddr *address,socklen_t address_len) 调用成功返回0,否则返回-1 并置errno33通讯套接字操作函数#include 1. int listen(int socket,int backlog); backlog: 指明套接字侦听队列允许悬挂连接请求个数 2. Int accept(int socket ,struct sockaddr *address , socklen_t *address_len); 说明:1. 创建一个新套接字与客户通信,并返回该套接字的描述符。2. Struct sockaddr 如不为空,则将被连接客户对应地址存储在该结构中。34通讯套接字例题1. 获取主机已存在的服务 2. 客户服务的套接字通讯35

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号