管道api简解



管道:
用于进程间通信,在内存中开辟出的一小块空间,进程间通信的管道为半双工。
管道的分类:
1.有名管道:命令:mkfifo+(管道名称)  自己建立管道,该命令对于linux新一些版本
基本可用。
2.无名管道:函数:pipe() 多用于父子进程的进程间通信

编程注意:
(1)管道的读端read在写端未关闭时阻塞,假设此时管道中没有数据。当写端关闭
读端会返回0。当我们管道中有数据时候read会循环读取,知道写端关闭后我们
设置返回值大于0的条件就可以有效的控制读端。
(2)int dup(int file_descriptor);eg:假设我们管道文件描述符是3,我们首
先要close(0),然后再dup(3)这样3这个管道的另一个描述符就是0;它的返回值总是
取最小可用值。


有名管道程序:
mkfifo fifo建立管道fifo
写端:
int main()
{
 int fd=open("fifo",O_WRONLY);//头文件fcntl.h,fifo在当前目录下,否则要写
绝对路径
 assert(fd!=-1);
 
 while(1)
 {
  char buff[128]={0};
  printf("input:\n");
  fgets(buff,127,stdin);
  if(buff=="end")
  {
   break;
  }
  write(fd,buff,128);//头文件unistd.h
 }
 close(fd); 
}

读端:
int main()
{
 int fd=open("fifo",O_RDONLY);
 assert(fd!=-1);
 char buff[128]={0};

 while(1)
 {
  if(read(fd,buff,127)<=0)
  {
   break; 
  }
  printf("%s",buff);
  memset(buff,0,128);
 }
 close(fd);
}

猜你喜欢

转载自blog.csdn.net/qq_41784469/article/details/79450244
今日推荐