操作系统实验报告 实验三、进程通信(一) ——管道及共享内存 一、 实验目的 熟悉和掌握 LINUX 系统的管道通信和共享内存通信
二、 实验内容 (一)、管道通信 1 、实验原理: 管道是半双工的,数据只能向一个方向流动;需要双方通信时,需要建立起两个管道; 单独构成一种独立的文件系统:管道对于管道两端的进程而言,就是一个文件,但它不是普通的文件,它不属于某种文件系统,而是自立门户,单独构成一种文件系统
数据的读出和写入:一个进程向管道中写的内容被管道另一端的进程读出
利用系统调用 pipe()可创建一个简单的管道
int fd[2]; pipe(fd); 调用成功,fd[0]存放供读进程使用的文件描述符(管道出口),fd[1]存放供写程使用的文件描述符(管道入口)
一个进程在由 pipe()创建管道后,一般再 fork()一个子进程,然后通过管道实现父子进程间的通信,子进程将从父进程那里继承所有打开的文件描述符
则父子两个进程都能访问组成管道的两个文件描述符,这样子进程可以向父进程发送消息(或者相反)
发送进程利用文件系统的系统调用 write(fd[1],buf,size),把 buf 中 size 个字符送入 fd[1],接收进程利用 read(fd[0],buf,size),把从 fd[0]读出的 size 个字符置入 buf 中
这样管道按 FIFO(先进先出)方式传送信息
2 、实验内容: #include main() { int x,fd[2]; char buf[30],s[30]; pipe(fd); while ((x=fork())==-1); if (x==0) { close(fd[0]); printf("Child Process
\n"); strcpy(buf,"This is an example\n"); write(