无名管道

1)只能用于具有亲缘关系的进程之间的通信(无名管道是某一个进程创建的,不像普通文件有路径,在文件系统中是不可见的,其他进程要想打开,只能通过继承的方式去打开)

2)半双工的通信模式,具有固定的读端和写端

3)管道可以看成是一种特殊的文件,对于它的读写可以使用文件IO如read、write函数。

4)管道是基于文件描述符的通信方式。当一个管道建立时,它会创建两个文件描述符fd[0]和fd[1]。其中fd[0]固定用于读管道,而fd[1]固定用于写管道。

注意事项
1)当管道中无数据时,读操作会阻塞

2)管道中有数据,将写端关闭,可以将数据读出

3)管道中无数据,将写端关闭,读操作会立即返回

4)管道中装满数据写阻塞,一旦有4k空间,写继续

5)只有在管道的读端存在时,向管道中写入数据才有意义。否则,会导致管道破裂,向管道中写入数据的进程将收到内核传来的SIGPIPE信号(通常Broken        pipe错误)。

6)不管pipe还是FIFO当把读端和写端都关闭的时候,管道存放在内存中的内容都会被自动释放

7)当用open打开的时候,当只打开读端,或者只打开写端,open会阻塞

创建无名管道

int pipe(int pipefd[2]);

参数:文件描述符 fd[0]:读端 fd[1]:写端

成功返回 0 ,失败返回 -1

 例子1:管道中没有数据时读操作阻塞

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, const char *argv[])
{
int fd[];
char buf[] = {};//缓存 if(pipe(fd)!=)// 创建无名管道
{
perror("pipe fail: ");
exit();
}
printf("%d %d\n",fd[],fd[]);//打开的文件描述符,此处为3,4 默认打开 0,1,2,标准输入,输出,出错
//管道中没有数据的时候读阻塞
// write(fd[],"hello",); //此处不向管道写数据时,读操作会阻塞,管道中有数据时,读操作后结束进程
read(fd[],buf,);
printf("%s",buf);
putchar(); // '\n'
return ;
}

测试:读操作一直阻塞

 例子2:管道中有数据,将写端关闭,可以将数据读出

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, const char *argv[])
{
int fd[];
char buf[] = {};//缓存
if(pipe(fd)!=)// 创建无名管道
{
perror("pipe fail: ");
exit();
}
printf("%d %d\n",fd[],fd[]);//打开的文件描述符,默认打开 0,1,2
//管道中有数据,写端关闭,可以将数据读出
write(fd[],"",); //向管道中写入数据,然后关闭写端
close(fd[]);
read(fd[],buf,);
printf("%s",buf);
putchar(); // '\n'
return ;
}

测试:

例子3:管道中无数据,将写端关闭,读操作会立即返回

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, const char *argv[])
{
int fd[];
char buf[] = {};//缓存
if(pipe(fd)!=)// 创建无名管道
{
perror("pipe fail: ");
exit();
}
printf("%d %d\n",fd[],fd[]);//打开的文件描述符,默认打开 0,1,2
//写端关闭,管道中无数据,读操作立即返回
close(fd[]);
read(fd[],buf,); return ;
}

测试:管道中无数据,写端关闭,读操作直接返回

 例子4:管道大小 64K

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h> int main(int argc, const char *argv[])
{
int fd[];
char buf[] = {};//缓存
if(pipe(fd)!=)// 创建无名管道
{
perror("pipe fail: ");
exit();
}
printf("%d %d\n",fd[],fd[]);//打开的文件描述符,默认打开 0,1,2
//管道大小 64k
int num = ;
ssize_t size;
while() //循环一直运行,当写入 64K 后悔阻塞
{
size = write(fd[],"",);
printf("size = %ld\n",size); //每次写入1024个字节,即 1K ,此次编译会警告
num++;
printf("num = %d\n",num);
}
return ;
}

测试:

警告类型不匹配

 例子5: 管道中装满数据写阻塞,一旦有4k空间,写继续

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h> //int pipe(int pipefd[2]); int main(int argc, const char *argv[])
{
int fd[]; char buf_w[] = {}; //一次写入 64K 数据
char buf_r[] = {}; //一次读出 4K 数据 if(pipe(fd)!=)// 创建无名管道
{
perror("pipe fail: ");
exit();
} printf("%d %d\n",fd[],fd[]);//打开的文件描述符,默认打开 0,1,2 //管道中装满数据写阻塞,一旦有 4k, 才可以继续进行写操作
write(fd[],buf_w,);//一次写入 64k
// read(fd[0],buf_r,4096); //一次读出4k,在进行写操作 ,程序直接结束
read(fd[],buf_r,); //一次读出 4k-1,在进行写操作 ,此时运行程序阻塞
write(fd[],"a",); // 先读出 4K 数据在写一个字符,或者读4K - 1 个字符,在进行写操作 return ;
}

测试:当读出 4K 数据时可以正常写入,当读出 4K-1 数据时 程序阻塞

Linux 进程间通信 无名管道(pipe)的更多相关文章

  1. Linux 进程间通信之管道(pipe),(fifo)

     无名管道(pipe) 管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道所具有的功能外,它还允许无亲缘关系进程间的通信: 定义函数: int pipe(int f ...

  2. linux进程间通信--无名管道

    管道 只能用于具有亲缘关系的进程之间通信是一个半双工的通信模式, 具有固定的写读端和写端,管道可以看成一种特殊的文件,对它可以使用普通的read.write等操作 管道的创建: #include &l ...

  3. Linux进程间通信之管道(pipe)、命名管道(FIFO)与信号(Signal)

    整理自网络 Unix IPC包括:管道(pipe).命名管道(FIFO)与信号(Signal) 管道(pipe) 管道可用于具有亲缘关系进程间的通信,有名管道克服了管道没有名字的限制,因此,除具有管道 ...

  4. Linux简单程序实例(GNU工具链,进程,线程,无名管道pipe,基于fd的文件操作,信号,scoket)

    一, GNU工具链简介: (1)编译代码步骤: 预处理 -> 编译 -> 汇编 -> 链接: 预处理:去掉注释,进行宏替换,头文件包含等工作: gcc -E test.c -o te ...

  5. 练习--LINUX进程间通信之无名管道PIPE

    IBM上放的这个系统不错,刚好可以系统回温一下LINUX的系统知识. http://www.ibm.com/developerworks/cn/linux/l-ipc/part1/ 感觉年纪大了,前几 ...

  6. Linux进程间通信之管道

    1,进程间通信 (IPC ) Inter-Process Communication 比较好理解概念的就是进程间通信就是在不同进程之间传播或交换信息. 2,linux下IPC机制的分类:管道.信号.共 ...

  7. Linux 进程间通信(二) 管道

    Linux 进程间通信-管道 进程是一个独立的资源分配单位,不同进程之间的资源是相互独立的,没有关联,不能在一个进程中直接访问另一个进程中的资源.但是,进程不是孤立的,不同的进程之间需要信息的交换以及 ...

  8. Linux -- 进程间通信之管道

    管道是 Linux 里的一种文件类型,同时也是 Linux 系统下进程间通信的一种方式   创建一个管道文件有两种方式:  Shell 下命令 mkfifo + filename,即创建一个有名管道 ...

  9. linux之无名管道

    1.查看命令: man 2 pipe 2.头文件:#include <unistd.h> 3.函数原型: int pipe(int pipefd[2]); a.pipefd[2] :无名管 ...

随机推荐

  1. python之求字典最值

    本例子求字典最小值 首先字典分为键和值 eg: {键:值} prices = { 'ACME': 45.23, 'AAPL': 612.78, 'IBM': 205.55, 'HPQ': 37.20, ...

  2. 代理-jdk动态代理

    1.基于接口的实现,要jdk动态代理的类必须要实现一个接口: 2.中介类:实现了InvocationHandler,并重写这个接口的 方法(public Object invoke(Object pr ...

  3. sql语句练习50题(Mysql版-详加注释)

    表名和字段 1.学生表       Student(s_id,s_name,s_birth,s_sex) --学生编号,学生姓名, 出生年月,学生性别 2.课程表       Course(c_id, ...

  4. Python查看文件属性

    import os print(os.stat('my_module.py')) 输出: os.stat_result(st_mode=33188, st_ino=7348222, st_dev=16 ...

  5. Hadoop(三)YARN

    Yet Another Resources Negotiator 从Hadoop2.0版本开始引入YARN,主要功能: 集群资源管理系统 负责集群的统一管理和调度 与客户端交互,处理客户端请求 一.基 ...

  6. nc临时开启端口并监听

    port="6379 3306 27017 4505 4506 24007 24008 49152" #while true #do for i in $port do isexi ...

  7. PHP FILTER_VALIDATE_URL 过滤器

    定义和用法 FILTER_VALIDATE_URL 过滤器把值作为 URL 来验证. Name: "validate_url" ID-number: 273 可能的标志: FILT ...

  8. 【Codeforces Round #429 (Div. 2) C】Leha and Function

    [Link]:http://codeforces.com/contest/841/problem/C [Description] [Solution] 看到最大的和最小的对应,第二大的和第二小的对应. ...

  9. Elasticsearch之index_closed_exception

    索引的打开与关闭 关闭索引 POST /index_name/_close 尝试插入数据 PUT /shakespeare/_doc/ { "title":"kibana ...

  10. 在Visual C++中使用内联汇编

    一.内联汇编的优缺点 因为在Visual C++中使用内联汇编不需要额外的编译器和联接器,且可以处理Visual C++中不能处理的一些事情,而且可以使用在C/C++中的变量,所以非常方便.内联汇编主 ...