《操作系统课件os02进程通信和线程.ppt》由会员分享,可在线阅读,更多相关《操作系统课件os02进程通信和线程.ppt(63页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、操作系统操作系统Operating SystemsWINDOWSWINDOWSUNIXUNIXLINUXLINUXOS2OS2VxWorksVxWorksMacOSMacOS2.5进进程程通通信信进程通信:进程之间的信息交换,其所交换的信息量:进程通信:进程之间的信息交换,其所交换的信息量:一个状态或数值一个状态或数值成千上万个字节成千上万个字节低级通信:低级通信:进程之间的互斥和同步进程之间的互斥和同步交换量的比较少交换量的比较少高级通信:高级通信:用户可直接利用用户可直接利用OS所提供的一组所提供的一组通信命令通信命令高效地传送高效地传送大大量数据量数据的一种通信方式。的一种通信方式。进程
2、通信的类型进程通信的类型1共享存储器系统共享存储器系统基于共享数据结构的通信方式基于共享数据结构的通信方式基于共享存储区的通信方式基于共享存储区的通信方式2消息传递系统消息传递系统3管道通信系统管道通信系统1共享存储器系统共享存储器系统基于共享数据结构的通信方式基于共享数据结构的通信方式诸进程公用某些数据结构诸进程公用某些数据结构如:在生产者如:在生产者消费者问题消费者问题增加了程序员的负担增加了程序员的负担OS只须提供共享存储器只须提供共享存储器低效的,只适于传递相对少量的数据。低效的,只适于传递相对少量的数据。共享存储器系统共享存储器系统基于共享存储区的通信方式基于共享存储区的通信方式诸进
3、程通过对共享存储区中数据的读或写来实现通信。诸进程通过对共享存储区中数据的读或写来实现通信。通信方式属于高级通信通信方式属于高级通信先向系统申请获得共享存储区中的一个分区先向系统申请获得共享存储区中的一个分区像读、写普通存储器一样地读、写该公用存储分区。像读、写普通存储器一样地读、写该公用存储分区。进程进程1 1进程进程2 2 物理主存物理主存共享主存共享主存2消息传递系统消息传递系统属于高级通信方式属于高级通信方式程序员直接利用操作系统提供的一组程序员直接利用操作系统提供的一组通信命令通信命令(原语原语)进程间的数据交换进程间的数据交换以格式化的消息以格式化的消息(message)为单位的为
4、单位的因实现方式的不同而进一步分成:因实现方式的不同而进一步分成:直接通信方式直接通信方式间接通信方式间接通信方式3管道通信管道通信管道管道是指用于连接一个读进程和一个写进程以实现它们之是指用于连接一个读进程和一个写进程以实现它们之间通信的一个间通信的一个共享文件共享文件,又名,又名pipe文件。文件。写进程写进程共享文件共享文件读进程读进程管道机制必须的协调能力管道机制必须的协调能力1.互斥互斥2.同步同步当写进程把一定数量的数据写入当写进程把一定数量的数据写入pipe,便去睡眠等待,便去睡眠等待,读进程取走数据后,再把它唤醒。读进程取走数据后,再把它唤醒。当读进程读一空当读进程读一空pip
5、e时,也应睡眠等待时,也应睡眠等待写进程将数据写入管道后,才将之唤醒。写进程将数据写入管道后,才将之唤醒。3.确定对方是否存在确定对方是否存在只有确定了对方已存在时,才能进行通信。只有确定了对方已存在时,才能进行通信。2.5.2消息传递通信的实现方法消息传递通信的实现方法直接通信方式直接通信方式间接通信方式间接通信方式1.直接通信方式直接通信方式发发送送进进程程利利用用OS所所提提供供的的发发送送命命令令,直直接接把把消消息息发发送送给给目目标进程。标进程。系统提供下述两条通信命令系统提供下述两条通信命令(原语原语):Send(Receiver,message);发送一个消息给接收进程;发送一
6、个消息给接收进程Receive(Sender,message);接收;接收Sender发来的消息发来的消息要求发送进程和接收进程都以显式方式提供对方的标识符要求发送进程和接收进程都以显式方式提供对方的标识符原语原语Send(P2,m1)原语原语Receive(P1,m1)解决生产者解决生产者消费者问题消费者问题repeatproduceaniteminnextp;send(consumer,nextp);untilfalse;repeatreceive(producer,nextc);consumetheiteminnextc;untilfalse2.间接通信方式间接通信方式进程之间的通信需要
7、通过作为进程之间的通信需要通过作为共享数据结构共享数据结构的实体。的实体。该实体用来暂存发送进程发送给目标进程的消息;该实体用来暂存发送进程发送给目标进程的消息;接收进程从该实体中取出对方发送给自己的消息。接收进程从该实体中取出对方发送给自己的消息。这种中间实体称为信箱这种中间实体称为信箱消息在信箱中可以安全地保存,消息在信箱中可以安全地保存,只允许核准的目标用户随时读取。只允许核准的目标用户随时读取。信箱通信原语信箱通信原语1.信箱的创建和撤消。信箱的创建和撤消。创建者进程应给出信箱名字、信箱属性;创建者进程应给出信箱名字、信箱属性;对于共享信箱,还应给出共享者的名字。对于共享信箱,还应给出
8、共享者的名字。当进程不再需要读信箱时,可用信箱撤消原语将之撤当进程不再需要读信箱时,可用信箱撤消原语将之撤消消2.消息的发送和接收。消息的发送和接收。Send(mailbox,message);Receive(mailbox,message);信箱分类信箱分类私用信箱私用信箱公用信箱公用信箱共享信箱共享信箱私用信箱私用信箱用用户户进进程程可可为为自自己己建建立立一一个个新新信信箱箱,并并作作为为该该进进程程的的一一部部分。分。当拥有该信箱的进程结束时,信箱也随之消失。当拥有该信箱的进程结束时,信箱也随之消失。可采用可采用单向通信链路单向通信链路的信箱来实现的信箱来实现信箱的拥有者有权从信箱中读
9、取消息,信箱的拥有者有权从信箱中读取消息,其他用户只能将自己构成的消息发送到该信箱中。其他用户只能将自己构成的消息发送到该信箱中。公用信箱公用信箱它由它由操作系统操作系统创建,提供给系统中的创建,提供给系统中的所有核准进程所有核准进程使用。使用。公用信箱在系统运行期间公用信箱在系统运行期间始终存在始终存在。公用信箱应采用公用信箱应采用双向通信链路双向通信链路的信箱来实现。的信箱来实现。核准进程既可把消息发送到该信箱中,核准进程既可把消息发送到该信箱中,也可从信箱中读取发送给自己的消息。也可从信箱中读取发送给自己的消息。共享信箱共享信箱由由某进程某进程创建,创建时提供共享进程(用户)的名字创建,
10、创建时提供共享进程(用户)的名字拥有者和共享者均可读取自己消息。拥有者和共享者均可读取自己消息。消息传递系统实现中的若干问题消息传递系统实现中的若干问题1通信链路通信链路建立通信链路的方式建立通信链路的方式(1)由发送进程在通信之前用显式的由发送进程在通信之前用显式的“建立连接建立连接”命令命令(原语原语)请求系统为之建立一条通信链路;请求系统为之建立一条通信链路;主要用于计算机网络中。主要用于计算机网络中。(2)发送进程无须明确提出建立链路的请求,只须利用系统提发送进程无须明确提出建立链路的请求,只须利用系统提供的供的发送命令发送命令(原语原语),系统会自动地为之建立一条链路。,系统会自动地
11、为之建立一条链路。主要用于单机系统中。主要用于单机系统中。通信链路通信链路根据通信链路的连接方法,可把通信链路分为两类:根据通信链路的连接方法,可把通信链路分为两类:(1)点点点连接通信链路;点连接通信链路;(2)多点连接链路,指用一条链路连接多个多点连接链路,指用一条链路连接多个(n2)结点结点(进程进程)根据通信方式的不同,可把链路分成两种:根据通信方式的不同,可把链路分成两种:(1)单向通信链路;单向通信链路;(2)双向通信链路;双向通信链路;根据通信链路容量,把链路分成两类:根据通信链路容量,把链路分成两类:(1)无容量通信链路;)无容量通信链路;(2)有容量通信链路)有容量通信链路2
12、消息的格式消息的格式单机系统环境单机系统环境其消息格式比较简单;其消息格式比较简单;计算机网络环境计算机网络环境可把一个消息分成消息头和消息正文两部分。可把一个消息分成消息头和消息正文两部分。消息头包括消息在传输时所需的控制信息消息头包括消息在传输时所需的控制信息如源进程名、目标进程名、消息长度、消息类型、如源进程名、目标进程名、消息长度、消息类型、消息编号及发送的日期和时间;消息编号及发送的日期和时间;定长消息格式和变长消息格式定长消息格式和变长消息格式3同步方式同步方式send()时时阻塞:等待接收进程回答消息后,才继续进行阻塞:等待接收进程回答消息后,才继续进行非阻塞:发送方可继续运行非
13、阻塞:发送方可继续运行,直到某个时刻需要接收进程返直到某个时刻需要接收进程返回的回答消息后,才查询和处理。回的回答消息后,才查询和处理。Receive()时时阻塞:如果没有消息,接收进程会被阻塞,直到有消息;阻塞:如果没有消息,接收进程会被阻塞,直到有消息;如果有消息,则会立即获得一个消息并返回如果有消息,则会立即获得一个消息并返回非阻塞:查询后,立即返还控制给调用进程;如果有消息,非阻塞:查询后,立即返还控制给调用进程;如果有消息,就返回消息;否则表明无消息可用。这种方法允许接收进就返回消息;否则表明无消息可用。这种方法允许接收进程轮询信箱程轮询信箱通信进程的同步通信进程的同步发送进程阻塞,
14、接收进程阻塞发送进程阻塞,接收进程阻塞主要用于进程之间紧密同步主要用于进程之间紧密同步发送进程和接收进程之间无缓冲时。发送进程和接收进程之间无缓冲时。发送进程不阻塞,接收进程阻塞。发送进程不阻塞,接收进程阻塞。应用最广的进程同步方式应用最广的进程同步方式常用于服务进程常用于服务进程发送进程和接收进程均不阻塞。发送进程和接收进程均不阻塞。2.5.4 2.5.4 消息缓冲队列通信机制消息缓冲队列通信机制数据结构数据结构1).1).消息缓冲区:消息缓冲区:type message_buffer=recordtype message_buffer=record sendersender;发送进程标识符
15、;发送进程标识符 sizesize;消息长度消息长度 texttext;消息正文消息正文 nextnext;指向下一缓冲区指针指向下一缓冲区指针end end 2.5.4 2.5.4 消息缓冲队列通信机制消息缓冲队列通信机制2 2).PCB).PCB中有关通信的数据项:中有关通信的数据项:type processcontrol block=recordtype processcontrol block=record mqmq;消息队列队首指针消息队列队首指针 mutexmutex;消息队列互斥信号量消息队列互斥信号量 smsm;消息队列资源信号量消息队列资源信号量 end end 发送原语发送
16、原语proceduresend(receiver,a)begingetbuf(a.size,i);根据根据a.size申请缓冲区;申请缓冲区;i.sender=a.sender;i.size=a.size;i.text=a.text;i.next=0;getid(PCBset,receiver.j);获得接收进程内部标识符;获得接收进程内部标识符;wait(j.mutex);insert(j.mq,i);将消息缓冲区插入消息队列;将消息缓冲区插入消息队列;signal(j.mutex);signal(j.sm);end消息缓冲通信消息缓冲通信接收原语接收原语procedure receive(
17、b)Beginj:=internal name;j为接收进程内部的标识符;为接收进程内部的标识符;wait(j.sm);wait(j.mutex);remove(j.mq,i);将消息队列中第一个消息移出;将消息队列中第一个消息移出;signal(j.mutex);b.sender:=i.sender;将消息缓冲区;将消息缓冲区i中的信息复制到接收区中的信息复制到接收区b;b.size:=i.size;b.text:=i.text;end 2.6线程线程1线程的引入线程的引入在创建、撤消和切换中,系统必须为之付出较大的时空开在创建、撤消和切换中,系统必须为之付出较大的时空开销销进程数目不宜过多
18、,进程切换的频率也不宜过高。进程数目不宜过多,进程切换的频率也不宜过高。将拥有资源的单位和可独立调度将拥有资源的单位和可独立调度/分派的基本单位分离分派的基本单位分离2线程与进程的比较线程与进程的比较1)调度调度把线程作为调度和分派的基本单位把线程作为调度和分派的基本单位进程作为资源拥有的基本单位进程作为资源拥有的基本单位2)并发性并发性2线程与进程的比较线程与进程的比较3)拥有资源拥有资源4)系统开销系统开销进程进程 进程进程PCBPCB资源资源线程线程控制块控制块用户栈用户栈核心栈核心栈线程线程控制块控制块用户栈用户栈核心栈核心栈线程线程控制块控制块用户栈用户栈核心栈核心栈存储空间存储空间
19、全局数据全局数据程序代码程序代码线程线程1 1线程线程2 2线程线程控制块控制块线程线程i i线程线程n n3线程的属性线程的属性轻型实体。轻型实体。线程中的实体基本上不拥有系统资源线程中的实体基本上不拥有系统资源只是有一点必不可少的、只是有一点必不可少的、能保证其独立运行的资源能保证其独立运行的资源独立调度和分派的基本单位。独立调度和分派的基本单位。线程的切换非常迅速且开销小。线程的切换非常迅速且开销小。可并发执行。可并发执行。共享进程资源。共享进程资源。3线程的状态线程的状态线程的运行状态线程的运行状态执行状态执行状态就绪状态就绪状态阻塞状态阻塞状态线程的状态转换也类似于进程。线程的状态转
20、换也类似于进程。6多线程多线程OS中的进程中的进程在多线程在多线程OS中的进程具有的属性:中的进程具有的属性:(1)作为系统资源分配的单位。作为系统资源分配的单位。(2)可包括多个线程:至少也要有一个线程可包括多个线程:至少也要有一个线程(3)进程不是一个可执行的实体。进程不是一个可执行的实体。进程仍具有进程仍具有与执行相关的状态与执行相关的状态对进程所施加的与进程状态有关的操作,也对其线程对进程所施加的与进程状态有关的操作,也对其线程起作用起作用进程挂起和激活进程挂起和激活2.6.3线程的实现方式线程的实现方式从实现角度看,线程分成从实现角度看,线程分成:用户级线程用户级线程ULT如如Jav
21、a线程库线程库内核支持线程内核支持线程KST如如Window2003、OS/2。混合式线程混合式线程如如Solaris1内核支持线程内核支持线程进程中的线程的创建、撤消和切换等都是利用进程中的线程的创建、撤消和切换等都是利用系统调用系统调用进入内核,再由内核中相应的处理程序完成的。进入内核,再由内核中相应的处理程序完成的。内核支持线程主要优点内核支持线程主要优点多处理器上,内核能同时调度同一进程中多个线程多处理器上,内核能同时调度同一进程中多个线程并行执行并行执行进程中的一个线程被阻塞了,内核能调度同一进程的其它线进程中的一个线程被阻塞了,内核能调度同一进程的其它线程占有处理器运行。程占有处理
22、器运行。内核支持线程数据结构和堆栈很小,线程切换较快内核支持线程数据结构和堆栈很小,线程切换较快内核自身也可用多线程技术实现,能提高系统的执行速度和内核自身也可用多线程技术实现,能提高系统的执行速度和效率。效率。内核支持线程的主要缺点内核支持线程的主要缺点对于用户的线程切换而言,其模式切换的开销较大对于用户的线程切换而言,其模式切换的开销较大2用户级线程用户级线程用户级线程用户级线程仅存在于用户空仅存在于用户空间中间中线程管理工作线程管理工作无须利用系统无须利用系统调用来实现,调用来实现,由用户空间中由用户空间中的线程库来完成。的线程库来完成。内核不知道线程的存在内核不知道线程的存在用户级线程
23、用户级线程调度单位调度单位内核支持线程内核支持线程用户用户级线程级线程用户级线程(用户级线程(ULT)优点)优点线程切换不需要转换到内核空间线程切换不需要转换到内核空间调度算法可以是进程专用的。调度算法可以是进程专用的。用户级线程的实现与操作系统平台无关用户级线程的实现与操作系统平台无关用户级线程(用户级线程(ULT)的缺点)的缺点系统调用的阻塞问题。系统调用的阻塞问题。多线程应用不能利用多处理机进行多重处理的优点:多线程应用不能利用多处理机进行多重处理的优点:内核在一段时间里,分配一个进程仅占用一个内核在一段时间里,分配一个进程仅占用一个CPU进程中仅有一个线程能执行。进程中仅有一个线程能执
24、行。CPU3组合方式组合方式线程的实现两个层次:线程的实现两个层次:用户层和核心层用户层和核心层内核支持多内核支持多KSTKST的建立、调度和的建立、调度和管理;管理;允许应用程序建立、调度和管允许应用程序建立、调度和管理理ULTULT。组合方式组合方式应用程序的多个应用程序的多个ULTULT能分配和对应于能分配和对应于一个或多个一个或多个KLT.KLT.一个应用中的多个线程能同时在多一个应用中的多个线程能同时在多处理器上并行运行处理器上并行运行阻塞一个线程时并不需要封锁整个阻塞一个线程时并不需要封锁整个进程。进程。用用户户空空间间线程库线程库P P内内核核空空间间P P作业作业P833436
25、37UNIXUNIX系统系统UNIX系统最本质的特征是开放性。系统最本质的特征是开放性。所谓开放性,是指系统遵循国际标准规范;凡遵循国际标所谓开放性,是指系统遵循国际标准规范;凡遵循国际标准所开发的硬件和软件,均能彼此兼容,并可方便地实现准所开发的硬件和软件,均能彼此兼容,并可方便地实现互连。互连。人们普遍认为人们普遍认为:UNIX是目前开放性最好的是目前开放性最好的OS,是目前惟一能稳定运行,是目前惟一能稳定运行在从微型机到大、中型等各种机器上的在从微型机到大、中型等各种机器上的OS还能方便地将已配置了还能方便地将已配置了UNIXOS的机器互连成计算机的机器互连成计算机网络。网络。UNIX系
26、统是一个多用户、多任务系统是一个多用户、多任务OSUNIX核心的框图核心的框图 进程控制进程控制创建进程创建进程(fork)。终止进程终止进程(exit)。等待子进程结束等待子进程结束(wait)。用于将调用进程挂起,直至其子进程因暂停或终止而用于将调用进程挂起,直至其子进程因暂停或终止而发来软中断信号为止。发来软中断信号为止。父进程可以利用父进程可以利用wait使自身的执行与子进程的终止同步。使自身的执行与子进程的终止同步。获得进程获得进程ID创建进程创建进程fork()-父子进程是独立的进程父子进程是独立的进程p创建一个新进程创建一个新进程,即,即调用调用fork()父进程的副本,称为子父
27、进程的副本,称为子进程。进程。p子进程继承了父进程的许多特性。子进程继承了父进程的许多特性。p父进程与子进程并发执行父进程与子进程并发执行进程的创建进程的创建系统调用格式:系统调用格式:intpid=fork();fork()返回值意义如下:返回值意义如下:0:在子进程中,:在子进程中,pid变量保存的变量保存的fork()返回值为返回值为0,表示当前,表示当前进程是子进程。进程是子进程。对子进程返回对子进程返回00:在父进程中,:在父进程中,pid变量保存的变量保存的fork()返回值为子进程的返回值为子进程的id值值。向父进程返回子进程的进程号向父进程返回子进程的进程号-1:创建失败:创建
28、失败。进程的创建进程的创建实例:编写一段程序,使用系统调用实例:编写一段程序,使用系统调用fork()创建一个子进创建一个子进程。程。当此程序运行时,在系统中有一个父进程和一个子进当此程序运行时,在系统中有一个父进程和一个子进程活动。程活动。让每一个进程在屏幕上显示不同的字符串:让每一个进程在屏幕上显示不同的字符串:子进程显示子进程显示这是子进程这是子进程父进程显示父进程显示这是父进程这是父进程main()pid_tpid;printf(“PID);pid=fork();if(pid!=0)printf(“这是父进程这是父进程”);elseprintf(“这是子进程这是子进程);main()p
29、id_tpid;printf(“PID);pid=fork();if(pid!=0)printf(“这是父进程这是父进程”);elseprintf(“这是子进程这是子进程);main()pid_tpid;printf(“PID);pid=fork();if(pid!=0)printf(“这是父进程这是父进程”);elseprintf(“这是子进程这是子进程);父进程父进程父进程父进程子进程子进程分裂分裂执执行行继继续续执执行行继继续续执执行行信号机制信号机制信号机制信号机制主要是作为在主要是作为在同一用户同一用户的诸进程之间通信的简单工具的诸进程之间通信的简单工具信号本身是一个信号本身是一个1
30、19中的某个整数中的某个整数用来代表某一种事先约定好的简单消息用来代表某一种事先约定好的简单消息发送信号发送信号可利用系统调用可利用系统调用kill向另一进程或一组进程向另一进程或一组进程发送发送一个一个信信号号。表示某进程已发生了某种异常事件表示某进程已发生了某种异常事件信号机制信号机制每个进程在执行时,都要通过信号机制来每个进程在执行时,都要通过信号机制来检查检查是否有是否有信号信号到达。到达。若有信号到达,则:若有信号到达,则:立即中断正在执行的进程立即中断正在执行的进程转向转向由该信号由该信号(某整数某整数)所指示的所指示的处理程序处理程序,去完成对所,去完成对所发生的事件发生的事件(
31、事先约定事先约定)的处理。的处理。处理完毕,再处理完毕,再返回返回到此前的到此前的断点断点处继续执行。处继续执行。预置处理方式预置处理方式系统调用系统调用signalsignal(sig(sig,func)func)参数参数sigsig为信号名为信号名funcfunc用于预置处理方式,可分成三种情况:用于预置处理方式,可分成三种情况:(1)func=1(1)func=1时,进程对时,进程对sigsig类信号不予理睬。类信号不予理睬。(2)func=0(2)func=0,为缺省值,进程在收到,为缺省值,进程在收到sigsig信号后应自我终止信号后应自我终止(3)func为为非非0、非非1类类整整
32、数数时时,就就把把func的的值值作作为为指指向向某某信信号处理程序的指针。号处理程序的指针。如如:signal(16,stop);/接收到软中断信号接收到软中断信号16,转,转stopProcessAbegin/*向向B发软中断信号发软中断信号16*/kill(B,16);endProcessBBeginsignal(16,stop);Endvoidstop()mark=0;管道机制管道机制管道的类型管道的类型无名管道无名管道(Unnamed Pipes)(Unnamed Pipes)这是一个临时文件,利用系统调用这是一个临时文件,利用系统调用pipe()建立。建立。只有调用只有调用pipe
33、的进程及其子孙进程才能利用该文件的进程及其子孙进程才能利用该文件(管道管道)进行通信进行通信有名管道有名管道(Named Pipes)(Named Pipes)利用利用mknod系统调用建立的系统调用建立的可以在文件系统中长期存在的、具有路径名的文件可以在文件系统中长期存在的、具有路径名的文件其它进程可以感知它的存在,并能利用该路径名来其它进程可以感知它的存在,并能利用该路径名来访问该文件。访问该文件。父进程:父进程:int fd2;int fd2;char OutPipe100,InPipe100;/char OutPipe100,InPipe100;/定义两个字符数组定义两个字符数组 pi
34、pe(fd);/pipe(fd);/创建创建无名管道无名管道 read(fd0,InPipe,50);read(fd0,InPipe,50);子进程子进程write(fd1,OutPipe,50);write(fd1,OutPipe,50);/向管道写入数据向管道写入数据 消息机制消息机制消息消息(message)(message)消息是一个格式化的、可变长度的信息单元。消息是一个格式化的、可变长度的信息单元。消息机制允许进程发送一个消息给任何其它进程。消息机制允许进程发送一个消息给任何其它进程。消息队列消息队列当一个进程收到由其它多个进程发来的消息时,可将这些当一个进程收到由其它多个进程发来
35、的消息时,可将这些消息排成一个消息队列,消息排成一个消息队列,每个消息队列有一个称为每个消息队列有一个称为关键字关键字key的名称,它是由用户的名称,它是由用户指定的。指定的。消息队列的系统调用消息队列的系统调用1.1.系统调用系统调用msgget()建立一个指名的消息队列建立一个指名的消息队列2.2.msgctl()msgctl()系统调用系统调用对指定的消息队列进行操纵。对指定的消息队列进行操纵。3.3.消息发送系统调用消息发送系统调用msgsnd()核心唤醒在等待消息到来的睡眠进程。核心唤醒在等待消息到来的睡眠进程。4.4.消息的接收系统调用消息的接收系统调用msgrcv()从指定消息队
36、列中读一个消息。从指定消息队列中读一个消息。voidCLIENT()msgqid=msgget(MSGKEY,0777|IPC_CREAT);msgsnd(msgqid,&msg,1030,0);/*发送消息发送消息msg入入msgqid消息队列消息队列*/voidSERVER()msgqid=msgget(MSGKEY,0777|IPC_CREAT);/*由关键字获得消息队列由关键字获得消息队列*/msgrcv(msgqid,&msg,1030,0,0);/*从队列从队列msgqid接受消息接受消息msg*/msgctl(msgqid,IPC_RMID,0);共享存储区机制共享存储区机制共享
37、存储区机制是共享存储区机制是UNIX系统中通信速度最高的一种通信系统中通信速度最高的一种通信机制。机制。共享存储区的系统调用共享存储区的系统调用1.1.系统调用系统调用shmget()建立一块共享存储区建立一块共享存储区2.shmctl()系统调用系统调用共享存储区的操纵共享存储区的操纵3.3.系统调用系统调用shmat()将该共享存储区附接到用户给定的某个进程的虚地址将该共享存储区附接到用户给定的某个进程的虚地址shmaddr上,上,4.4.系统调用系统调用shmdt()利用该调用把该区与进程断开。利用该调用把该区与进程断开。ProcessABegin shmid=shmget(SHMKEY,1024,0777|IPC_CREAT);addr=shmat(shmid,0,0);*addr=-1;shmctl(shmid,IPC_RMID,0);end