函数
创建管道 知识点
进程间通信的基本概念
对进程间通信的基本理解通过管道实现进程间通信 实例 函数 创建管道
#include
进程间通信(Inter Process Communication)意味着两个不同进程间可以交换数据,为完成这点,操作系统中应提供两个进程可以同时访问的内存空间。
对进程间通信的基本理解 进程A通过某变量将自己的状态通知给进程B,进程B通过该变量了解到进程A的转台。即只要有两个进程可以同时访问的内存空间,就可以通过此空间交换数据。
但进程具有完全独立的内存结构,就连通过fork函数创建的子进程也不会与父进程共享内存空间。因此,进程间通信智能通过其他特殊方法形成。
为完成进程间通信,需创建管道。管道并非属于进程的资源,而是和套接字一样,属于操作系统,故两个进程通过操作系统提供的内存空间进行通信。
创建管道函数见函数区域。
###通过管道进行进程间双向通信
int fds[2];pipe(fds);pid_t pid=fork();if(pid==0){ write(fds[1),str1,sizeof(str));//写入管道 sleep(2); read(fds[0],buf,BUF_SIZE);//从管道读取}else//父进程{ read(fds[0],buf,BUF_SIZE);//从管道读取 sleep(2); write(fds[1],str2,sizeof(str2));//写入管道}
数据进入管道后成为无主数据,通过read函数先读取数据的进程将得到数据,即使进程将数据传到管道。
因此只使用1个管道进行双向通信并非易事,为此通过"创建2个管道"来实现双向通信,各自负责不同的数据流。
通过fork传递管道文件描述符:
通过1个管道实现双向通信:
通过2个管道实现双向通信:
保存消息的回声服务器端: