fifo与pipe

一、介绍

        进程通信中的有名管道(fifo)与无名管道(pipe)

特点fifopipe
使用场景任意进程之间具有亲缘的进程
通信全双工半双工
定位不支持不支持
长度上限4K4K

二、相关函数接口

1、pipe

头文件<stdio.h>

1、打开
int pipe(int fildes[2]);
返回值:
    成功:0
    失败:-1
参数:
    fildes[0]:读取句柄
    fildes[1]:写入句柄

2、关闭
close(fildes[0]);
close(fildes[1]);

3、读取
ssize_t read(int fd, void *buf, size_t count);
返回值:
    成功:返回读取长度
    失败:-1
参数:
    fd:文件描述符
    buf:读取保存空间
    count:读取长度
 
3、写入
ssize_t write(int fd, const void *buf, size_t count);
返回值:
    成功:写入长度
    失败:-1
参数:
    fd:文件描述符
    buf:写入内容
    count:写入长度

2、fifo

头文件

         <sys/types.h>
        <sys/stat.h>

1、创建管道
int mkfifo(const char *pathname, mode_t mode);
返回值:
    成功:0
    失败:-1
参数:
    pathname:管道文件路径
    mode:创建管道文件访问权限

2、卸载管道
int unlink(const char *pathname);
返回值:
    成功:0
    失败:-1
参数:
    pathname:管道文件路径

3、打开
int open(const char *pathname, int flags);
返回值:
    成功:文件描述符
    失败:-1
参数:
    pathname:文件路径
    flags:文件操作标志
        O_RDONLY    只读
		O_WRONLY    只写
		O_RDWR    读写

4、读取
ssize_t read(int fd, void *buf, size_t count);
返回值:
    成功:返回读取长度
    失败:-1
参数:
    fd:文件描述符
    buf:读取保存空间
    count:读取长度
 
5、写入
ssize_t write(int fd, const void *buf, size_t count);
返回值:
    成功:写入长度
    失败:-1
参数:
    fd:文件描述符
    buf:写入内容
    count:写入长度

6、关闭
close(fd);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值