linux pipe系统调用学习
2009-07-12 19:56
387 查看
linux 一切都是文件的概念实在很强大。pipe也是一种文件。
linux pipe系统调用原型
pipe是进程间共享的。由其系统调用生成的两个文件符也是进程间共享的。
其中规定 fd[0] 文件符只能进行读操作,fd[1]文件符只能进行写操作。
反之则未定义。
由于是文件符,所以只能用操作底层的读写操作,read, write。 它们的原型是:
当读pipe文件时,如果没有数据可读read将会阻塞。直到有数据为止。然而如果
进程没有打开的pipe文件来进行写操作时(即所有用于写的pipe文件符都被关闭),
read将会返回0而退出阻塞。但对于普通的文件描述符,如果一进程关闭了,另一进程
进行读的时候就出错。并且,当没数据时,普通文件描述符读时会立返回0而不阻塞。(标准输入除外)。
注意这里的区别。
linux pipe系统调用原型
#include<unistd.h> int pipe(int fd[2]); //该函数参数为一个长度为2的整型数组,是两个文件描述符。 //返回值,0为调用成功,-1为调用失败。
pipe是进程间共享的。由其系统调用生成的两个文件符也是进程间共享的。
其中规定 fd[0] 文件符只能进行读操作,fd[1]文件符只能进行写操作。
反之则未定义。
由于是文件符,所以只能用操作底层的读写操作,read, write。 它们的原型是:
#include<unistd.h> size_t read(int fd, void *buff, size_t len); //从fd中读出len字节写入buff中。返回实际读入的字节数。 //返回-1出错,无数据可读时或到文件尾时返回0 size_t write(int fd, const void *buff, size_t len); //把buff中len长的数据写入文件描述符。返回实际写入的字节数。 //-1表示出错
当读pipe文件时,如果没有数据可读read将会阻塞。直到有数据为止。然而如果
进程没有打开的pipe文件来进行写操作时(即所有用于写的pipe文件符都被关闭),
read将会返回0而退出阻塞。但对于普通的文件描述符,如果一进程关闭了,另一进程
进行读的时候就出错。并且,当没数据时,普通文件描述符读时会立返回0而不阻塞。(标准输入除外)。
注意这里的区别。
相关文章推荐
- Linux内核学习之系统调用
- linux系统调用学习笔记
- 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux系统调用的实现机制分析
- Linux第五周学习总结——扒开系统调用的三层皮(下
- Linux-0.11内核学习笔记【2】:添加系统调用
- Linux系统调用过程学习笔记
- 学习Linux:用read()系统调用读取文件
- Linux 内核学习——系统调用(fork)
- LS8-linux系统调用方式文件编程之学习笔记
- 汇编学习——使用Linux系统调用
- 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux系统调用的实现机制分析
- 学习笔记 --- LINUX 应用调试之添加系统调用
- Linux学习记录--进程控制相关系统调用 推荐
- 20135337朱荟潼 Linux第五周学习总结——扒开系统调用的三层皮(下)
- 学习笔记 --- LINUX 应用调试之使用strace命令追踪系统调用
- 20135337朱荟潼 Linux第四周学习总结——扒开系统调用的三层皮(上)
- Linux系统调用及用户编程接口(API)学习
- Linux内核学习笔记1——系统调用原理【转】
- linux学习--理解系统调用
- 【嵌入式Linux学习七步曲之第五篇 Linux内核及驱动编程】Linux系统调用的实现机制分析