- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验三使用Linux高级IPC 陈毅东 提纲 进程间通信概述 目标问题——哲学家进餐问题 问题描述 错误与不好的解法 并行度较高的解法 Linux高级IPC机制 概述 System V信号灯 System V共享内存区 实现的其他问题 实习题 进程间通信概述(1):引子 #include unistd.h#include sys/types.hint result;main(){ pid_t pid; result=0; pid=fork(); if(pid0) exit(-1); 进程间通信概述(2) 进程是相互独立的,进程间的通信需要专门的机制。 进程之间的通信可以经由文件系统,但实际使用较为复杂(例如,需要锁机制)。 UNIX IPC (InterProcess Communication)机制是各种进程通信方式的统称。 Linux下的进程通信手段基本上是从Unix平台上的进程通信手段继承而来的。 进程间通信概述(3) 对于UNIX的发展,贝尔实验室和BSD在进程间通信方面的侧重点有所不同: 贝尔实验室对Unix早期的进程间通信手段进行了系统的改进和扩充,形成了“System V IPC”,通信进程局限在单个计算机内; BSD则主要考虑跨计算机的进程间通信,形成了基于套接口(socket)的进程间通信机制。 进程间通信概述(4) 哲学家进餐问题的描述 五个哲学家围坐在一张圆桌周围,每个哲学家面前都有一碗米饭,相邻的两碗之间有一支筷子(如图)。 哲学家的生活包含两种活动:即吃饭和思考。当一个哲学家觉得饿时,他就试图分两次去取他左边和右边的筷子,每次拿起一支,但不分次序。如果成功地获得了一双筷子,他就开始吃饭,吃完以后放下筷子继续思考。这样,问题就是,为每个哲学家写一段程序来描述其行为,要求不死锁。 错误与不好的解法(1) 解法一:可能进入“死锁”状态 错误与不好的解法(2) #define N 5 void philosopher(int i) { while(TRUE){ think(); do{ take-chopstick(i); if(can-take-chopstick((i+1)%N)) break; else put-chopstick(i); }while(TRUE); eat(); put-chopstick(i);put-chopstick((i+1)%N); } } 错误与不好的解法(3) #define N 5 typedef int semaphore; semaphore mutex=1; void philosopher(int i) { while(TRUE){ think(); down(mutex); take-chopstick(i); take-chopstick((i+1)%N); eat(); put-chopstick(i); put-chopstick((i+1)%N); up(mutex); } } 并行度较高的解法(1) #define N 5 #define LEFT (i+N-1)%N #define RIGHT (i+1)%N #define THINKING 0 #define HUNGRY 1 #define EATING 2 typedef int semaphore; int state[N]; semaphore mutex=1; semaphore s[N]; 并行度较高的解法(2) 概述 System V IPC包含了三种机制,在实现“哲学家进餐问题”时,我们只使用信号灯机制和共享存储区机制。主要的函数如下: 信号灯 共享内存区 头文件 sys/sem.h sys/shm.h 创建或打开IPC semget shmget 控制IPC操作 semctl shmctl IPC操作函数 semop shmat, shmdt System V IPC对象以key_t类型的值作为其名字。 System V IPC对象以一定的存取权限来控制其访问。 System V IPC的名字 System V IPC是有名的,这样可以支持无亲缘关系的进程访问同一的IPC对象。其名字的类型为key_t,可以由ftok函数赋予或直接取值IPC_PRIVATE。 ftok函数 原型:#include sys/types.h #include sys/ipc.h key_t ftok
您可能关注的文档
- 评价结论及对策建议.doc
- 评监作业程序.doc
- 试用整流二极管三端稳压器7815.ppt
- 试验8材料的气敏性能测试草案一试验导读气敏材料概论在工业.doc
- 试验一Protel99SE设计环境认识.doc
- 试验一一阶单容上水箱对象特性测试试验.doc
- 试验一普通照明设备及控制电路安装与调试.doc
- 试验一气动-大连理工大学机械工程试验教学中心.ppt
- 试验动物管理规定-吉林大学生物基础国家级试验教学示范中心.doc
- 试验变压器的容量选择.doc
- 2026年保密员必考题库及完整答案(各地真题).docx
- 2026深圳空管站毕业生校园招聘4人参考试题附答案解析.docx
- 2026年保密员从业资格证考试题库【黄金题型】.docx
- 浙江国企招聘-2025中国联通春季校园招聘笔试历年题库附答案解析.docx
- 2026年保密员理论考试题库及参考答案(夺分金卷).docx
- 2026年保密员从业资格证考试题库(夺分金卷).docx
- 2026洱源县应急管理局公开招聘森林草原专业扑火队队员笔试题库(40人)附答案解析.docx
- 2026年版保密员(初级)内部模拟考试题库含完整答案【全国通用】.docx
- 2026招商银行杭州分行校园招聘笔试备考试题附答案解析.docx
- 贵州国企招聘:2025榕江县精开矿业有限责任公司招聘笔试历年题库带答案解析.docx
最近下载
- 2020年高考真题物理(山东卷)含答案.pptx VIP
- 药品网络交易服务第三方平台质量管理文件(目录).docx VIP
- 2025年暨南大学考研828管理学及微观经济学真题.pdf
- 2025《社区居家养老的有关概念及相关理论基础》4600字.docx
- (5.1.1)--5.1通风空调系统的分类及组成.ppt VIP
- 流行性感冒诊疗方案(2025年版)解读.pptx VIP
- “铸牢中华民族共同体意识”应知应会网络知识竞赛题库及答案.docx VIP
- 医疗器械网络交易服务第三方平台质量管理文件.pdf VIP
- 【通用】【人际交往】主题班会:不要回应“恶意 课件(共31张PPT).pptx VIP
- 部编版小学五年级语文上册第3课《桂花雨》精美课件(共66张PPT).pptx VIP
原创力文档


文档评论(0)