操作系统实验三进程的管道通信通信电子数据通信与网络_通信电子-数据通信与网络.pdf
《操作系统实验三进程的管道通信通信电子数据通信与网络_通信电子-数据通信与网络.pdf》由会员分享,可在线阅读,更多相关《操作系统实验三进程的管道通信通信电子数据通信与网络_通信电子-数据通信与网络.pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 实验三进程的管道通信 一、实验目的:(1)加深对进程概念的理解,明确进程和程序的区别;(2)学习进程创建的过程,进一步认识并发执行的实质;(3)分析进程争用资源的现象,学习解决进程互斥的方法;(4)学习解决进程同步的方法;(5)掌握 Linux 系统进程间通过管道通信的具体实现方法。二、实验内容及要求:(1)使用系统调用 pipe()建立一条管道线,两个子进程分别向管道写一句话(写的内容自己定,但要有该进程的一些信息);(2)父进程从管道中读出来自两个子进程的消息,显示在屏幕上;(3)要求:父进程首先接收子进程 p1 发来的消息,然后再接收子进程 p2 发来的消息;(4)两个子进程要并发执行
2、;(5)实现管道的互斥使用。当一个子进程正在对管道进行写操作时,另一个欲写入管道的子进程必须等待。使用系统调用lockf(fd1,1,0)实现对管道的加锁操作,用 lockf(fd1,0,0)解除对管道的锁定;(6)实现父子进程的同步,当父进程试图从一空管道中读取数据时,便进入等待状态,直到子进程将数据写入管道返回后,才将其唤醒。三、实现:相关的系统调用 fork()用于创一个子进程。格式:intfork();返回值:在子进程中返回 0;在父进程中返回所创建的子进程的 ID 值;当返回-1 时,创建失败。wait()常用来控制父进程与子进程的同步。在父进程中调用 wait(),则父进程被阻塞,
3、进入等待队列,等待子进 程结束。当子进程结束时,父进程从 wait()返回继续执行原来的程序。返回值:大于 0 时,为子进程的 ID 值;等于-1 时,调用失败。exit()是进程结束时最常调用的。格式:voidexit(intstatus);其中,status 为进程结束状态。pipe()用于创建一个管道 格式:pipe(intfd);其中 fd 是一个由两个数组元素 fd0 和 fd1 组成的整型 数组,fd0 是管道的读端口,用于从管道读出数据 ,fd1 是管道的写 端口,用于向管道写入数据。返回值:0 调用成功;-1 调用失败。sleep()使调用进程睡眠若干时间,之后唤醒。格式:sl
4、eep(intt);其中 t 为睡眠时间。lockf()用于对互斥资源加锁和解锁。在本实验中该调用的格式为:lockf(fd1,1,0);/*表示对管道的写入端口加锁。lockf(fd1,0,0);/*表示对管道的写入端口解锁。write(fd1,String,Length)将字符串 String 的内容写入管道的写入 口。read(fd0,String,Length)从管道的读入口读出信息放入字符串 String 中。程序流程图 图 1 父进程流程图图 2 子进程 P1 流程图 四、运行结果及说明 五、源代码 并发执行的实质分析进程争用资源的现象学习解决进程互斥的方法学习解决进程同步的方法掌
5、握系统进程间通过管道通信的具体实现方法二实验内容及要求使用系统调用建立一条管道线两个子进程分别向管道写一句话写的内容自己发来的消息然后再接收子进程发来的消息两个子进程要并发执行实现管道的互斥使用当一个子进程正在对管道进行写操作时另一个欲写入管道的子进程必须等待使用系统调用实现对管道的加锁操作用解除对管道的锁定实现父子进程相关的系统调用用于创一个子进程格式返回值在子进程中返回在父进程中返回所创建的子进程的值当返回时创建失败常用来控制父进程与子进程的同步在父进程中调用则父进程被阻塞进入等待队列等待子进程结束当子进程结束时父#include#include#include#include#inclu
6、de#include#include#include intmain()intpid1,pid2,pid3;intfd2;charoutpipe60,inpipe60;pipe(fd);/创建一个管道 while(pid1=fork()=-1);printf(pid1=%dn,pid1);if(pid1=0)printf(TheChildprocess1issendingmessage!n);lockf(fd1,1,0);/互斥 sprintf(outpipe,Thisisthechild1processsmessage!n);write(fd1,outpipe,60);sleep(1);/自
7、我阻塞 1 秒,让出机会执行下一个进程,增加并发度 lockf(fd1,0,0);exit(0);else while(pid2=fork()=-1);并发执行的实质分析进程争用资源的现象学习解决进程互斥的方法学习解决进程同步的方法掌握系统进程间通过管道通信的具体实现方法二实验内容及要求使用系统调用建立一条管道线两个子进程分别向管道写一句话写的内容自己发来的消息然后再接收子进程发来的消息两个子进程要并发执行实现管道的互斥使用当一个子进程正在对管道进行写操作时另一个欲写入管道的子进程必须等待使用系统调用实现对管道的加锁操作用解除对管道的锁定实现父子进程相关的系统调用用于创一个子进程格式返回值在子
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 实验 进程 管道 通信 电子 数据通信 网络
限制150内