FIFO:有名管道
原型:int mkfifo(const char *pathname,mode_t mode);头文件:sys/types.h和sys/stat.h
参数:创建的管道名字和操作权限
说明:可以在任意两个进程中通信
返回值:成功则返回0,否则返回-1,错误原因存于errno中
说明:1.管道有大小限制(4096B) 在写入数据之前,会先判断管道大小是否足够,若不够就不会写入
写满后只能等到有数据被读出才能继续写入.
2.read读数据是一定要读到数据才能返回的,否则就会等待,全部进程中必须有一个reader
是没有关闭的,才能write进数据.
3.writer设置成非阻塞,必须先运行readr,否则写端会受到警告No such device or address
4.open(fifo, O_RDONLY);open(fifo, O_WRONLY);这种是阻塞模式,不管先运行哪一个都会
等另一个进程open的时候才能open结束(,两个进程间?非父子进程)
原型:int mkfifo(const char *pathname,mode_t mode);头文件:sys/types.h和sys/stat.h
参数:创建的管道名字和操作权限
说明:可以在任意两个进程中通信
返回值:成功则返回0,否则返回-1,错误原因存于errno中
说明:1.管道有大小限制(4096B) 在写入数据之前,会先判断管道大小是否足够,若不够就不会写入
写满后只能等到有数据被读出才能继续写入.
2.read读数据是一定要读到数据才能返回的,否则就会等待,全部进程中必须有一个reader
是没有关闭的,才能write进数据.
3.writer设置成非阻塞,必须先运行readr,否则写端会受到警告No such device or address
4.open(fifo, O_RDONLY);open(fifo, O_WRONLY);这种是阻塞模式,不管先运行哪一个都会
等另一个进程open的时候才能open结束(,两个进程间?非父子进程)
5.open(fifo,O_RDONLY|O_NONBLOCK);open(fifo,O_WRONLY|O_NONBLOCK);非阻塞模式,
前者不用等写打开就可以open结束,但是先运行后者就不可以:说明3
父子进程间测试:
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
int main(void)
{
char buf[80];
int fd;
unlink(