ImageVerifierCode 换一换
格式:PPT , 页数:11 ,大小:78KB ,
资源ID:7091084      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-7091084.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(实验四 经典的进程同步问题.ppt)为本站会员(hwpkd79526)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

实验四 经典的进程同步问题.ppt

1、实 验 四,一、编程实现生产者消费者问题 二、进程间的通信 (软中断信号) 三、实验目的 1. 掌握进程同步的实现算法 1. 了解什么是信号 2. 熟悉LINUX系统中进程之间软中断通信的基本原理,实 验 四,四、实验任务1. 编写程序,创建生产者和消费者进程,生产者进程产生数据并写入缓冲区,消费者进程取数据并输出,缓冲区能存放四个数据,如果缓冲区满,则生产者不能写数据,并报警;如果缓冲区空,消费者不能取数据,并报警。(选做,2个生产者,2个消费者)2. 编写程序:用fork( )创建两个子进程,再用系统调用signal( )让父进程捕捉键盘上来的中断信号(即按c键);捕捉到中断信号后,父进程

2、用系统调用kill( )向两个子进程发出信号,子进程捕捉到信号后分别输出下列信息后终止:Child process1 is killed by parent!Child process2 is killed by parent!父进程等待两个子进程终止后,输出如下的信息后终止:Parent process is killed!,实 验 四,五、实验要求1. 阅读有关的参考书,学习系统功能调用kill( )、 signal( )的功能及用法2. 输入实验指导中的参考代码,编译并运行 能否得到结果?为什么?尝试修改源代码,得到预期的结果。3. 写实验报告,六、有关的系统功能调用:int kill(

3、pid_t pid, int sig); /向进程组或进程发送信号pid:1. pid大于零,pid是信号欲送往的进程的标识。2.pid等于零,信号将送往所有与调用kill()的那个进程属同一个使用组的进程。3. pid等于-1,信号将送往所有调用进程有权给其发送信号的进程,除了进程1(init)。4. pid小于-1时,信号将送往以-pid为组标识的进程。sig:准备发送的信号,其值为零则没有任何信号送出,六、有关的系统功能调用: signal(int sig,int function)/;预置对信号的处理方式int sig:信号void (*function) ( ) 接收到指定信号后的处

4、理函数,参数sig,#include #include #include void waiting( ),stop( ); int wait_mark; main( ) int p1,p2,stdout;while(p1=fork( )= =-1); /*创建子进程p1*/if (p10)while(p2=fork( )= =-1); /*创建子进程p2*/if(p20)wait_mark=1;,七、参考代码,signal(SIGINT,stop); /*接收到c信号,转stop*/ waiting( ); kill(p1,16); /*向p1发软中断信号16*/ kill(p2,17); /

5、*向p2发软中断信号17*/ wait(0); /*同步*/ wait(0); printf(“Parent process is killed!n“); exit(0); elsewait_mark=1;signal(17,stop); /*接收到软中断信号17,转stop*/waiting( );lockf(stdout,1,0);printf(“Child process 2 is killed by parent!n“);lockf(stdout,0,0);exit(0); ,else wait_mark=1; signal(16,stop); /*接收到软中断信号16,转stop*/

6、 waiting( ); lockf(stdout,1,0); printf(“Child process 1 is killed by parent!n“); lockf(stdout,0,0); exit(0); ,void waiting( ) while(wait_mark!=0); void stop( ) wait_mark=0; ,八、思考题,1、lockf(stdout,1,0)的作用是什么? 2、该程序段前面部分用了两个wait(0),它们起什么作用? 3、该程序段中每个进程退出时都用了语句exit(0),为什么? 4、为何预期的结果并未显示出? 5、程序该如何修改才能得到正确结果?,

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报