嵌入式linux的学习笔记-pipe管道(二)
今天学习了一下pipe管道,用于父子或者相关联的两个进程之间的通讯,pipe使用 pipe()函数建立,必须用于fork建立的进程中,并且需要在fork之前调用,否则是没有效果的,下面是一个例子和用法说明
#include <unistd.h>
#include <sys/types.h> //系统数据类型头文件
#include <errno.h> //出错类型头文件
#include <stdio.h> //标准输入输出
#include <stdlib.h> //标准系统库
int main(void)
{
int pipe_fd[2]; //创建管道描述符,其中pipe_fd[0]为接收描述符,pipe_fd[1]为写描述符
pid_t pid; //创建进程ID记录值
char buf[50]; //创建接收缓冲
char *p_wbuf; //创建写buf指针
int r_num; //创建接收数据数量记录值
memset(buf,0x00,sizeof(buf)); //清零buf
if(pipe(pipe_fd)<0)
{
//error 进行出错处理
}
if((pid=fork())==0)
{ //进入这里,说明在子进程中
/*在子进程中,子进程继承的是父进程的pipe_fd[2]描述符,因此,子进程的管道描述符和父进程的管道描述符是关联的,pipe管道只有关联的描 述符才可以传递数据,因此,pipe管道只能用于父子进程之间,两个不相关的进程是无法通过pipe进程 进行数据通信的 */
close(pipe_fd[1]); //在子进程中关闭写描述符
sleep(2); //在这里延时2秒
if((r_num=read(pipe_fd[0],buf,50))>0)
{
/***************************
read说明
read可以用来读取pipe管道,第一个参数
是读取管道描述符,第二个参数是接收缓存,第三个是
期望接收到的最大字符数,返回值是实际接收到的字符数
***************************/
/**********
为何休眠说明:
因此在运行read函数时,子进程会立即读取pipe管道,但是子进程在执行read时,
父进程可能还没有分叉(fork,因为根据系统调度机制的差异,并不一定是父进程在子进程之前运行的),所以等待2秒,确保父进程
已经执行了write函数;当子进程调用read时会读取管道中被写入的所有数据
***********/
printf("read string is : [ %s ]:size is %d \n",buf,r_num);
close(pipe_fd[0]); //工作完毕,关闭读管道描述符
exit(0); //程序退出
}else if(pid>0)
{
//注意这里,这里只有父进程会指向,所以这里的pid的值是子进程的ID号
close(pipe_fd[0]); //父进程只发送数据,关闭读管道描述符
write(pipe_fd[1],"Hello",5);
write(pipe_fd[1]," World",6);
/***************************
write说明
write可以用来写pipe管道,第一个参数
是写管道描述符,第二个参数是发送的缓冲或者字符串,第三个是
发送的字符数,返回值<0时表示发送失败
***************************/
close(pipe_fd[1]); //发送完毕,关闭写管道
sleep(1); //休眠一秒,可加可不加
waitpid(pid,NULL,0); //等待pid做指向的进程结束,否则则在这里堵塞
exit(0); //当判断上句成立,表示子进程关闭,这是父进程也关闭自身
}else
{
//子进程创建失败,进行出错处理
}
}
}