- 1、本文档共54页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
4.3.6 会合(Rendezvous) 背景 80年代, Ada, Initiated by DOD; Ada 95, (Object-oriented) 会合:两个并发执行流汇集到一处 并发执行流 调用 接受 均发生,握手,同步。 会合引入背景—分布系统 会合引入背景—分布系统 会合引入背景—分布系统 会合引入背景—分布系统 会合图示 会合图示 Ada同步语句 Accept语句 例子--单一资源管理 Ada同步语句(cont.) Select语句语义 4.3.6.2 会合例子--客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 客栈问题 Bounded buffer problem Bounded buffer problem Bounded buffer problem 读者-写者问题 Task readers_writers is entry start_read; entry finish_read; entry start_write; entry finish_write; End readers_writes; Task body readers_writers is; Var read_count, write_count: integer; begin read_count:=0; write_count:=0; 读者-写者问题 Loop select when write_count=0 = accept start_read do read_count := read_count+1; end start_read or when read_count0 = accept finish_read do read_count := read_count-1; end finish_read; or 读者-写者问题 when write_count=0 = accept start_write do while read_count 0 do accept finish_read do read_count:= read_count -1; end finish_read end while end start_write; write_count:=write_count+1; or when write_count0 = accept finish_write do write_count:=write_count-1; end finish_write; end select End loop; End readers_writers 读者-写者问题 读者活动: Readers_writes.start_read; 读操作 Readers_writers.finish_read; 写者活动: Readers_writers.start_write; 写操作 Readers_writers.finish_write; 4.4 进程高级通讯 进程通讯:进程之间的相互作用。 低级通讯(简单信号) 进程互斥 进程同步 高级通讯(大宗信息) 高级通讯 memory sharing vs. message passing direct vs. indirect symmetric vs. non-symmetric buffering vs. non-buffering 4.4.2 进程通讯模式 4.4.3 直接方式 对称形式(sender and receiver name each other) send(R,message) receive(S,mes
文档评论(0)