linux系统是一种支持多任务并发执行的操作系统,它可以同时运行多个进程,从而提高系统的利用率和效率。但是,如果这些进程之间需要进行数据交换和协作,就需要使用一些进程间通信(ipc)的方式,例如信号、消息队列、共享内存、信号量等。其中,有名管道(fifo)是一种比较简单而强大的ipc方式,它可以让两个或多个进程通过一个文件来进行数据传输,无需关心文件的内容和格式。本文将介绍linux系统中有名管道(fifo)的阻塞和非阻塞读写的方法,包括有名管道的创建、打开、读写、关闭和删除等方面。

Linux有名管道(FIFO):一种简单而强大的进程间通信方式

//写进程

#include

#include

#include

#include

#include

#include

#define FIFO_NAME “/tmp/myfifo”

main()

{

int fd;

char w_buf[50];

int w_num;

// 若fifo已存在,则直接使用,否则创建它

if((mkfifo(FIFO_NAME,0777)

{

printf(“cannot create fifo…\n”);

exit(1);

}

//以阻塞型只写方式打开fifo

fd=open(FIFO_NAME,O_WRONLY);

w_num=write(fd,”abcdg\0″,6);

printf(“%d\n”,w_num);

}

//读进程

#include

#include

#include

#include

#define FIFO_NAME “/tmp/myfifo”

main()

{

char r_buf[50];

int fd;

int r_num;

// 若fifo已存在,则直接使用,否则创建它

if((mkfifo(FIFO_NAME,0777)

{

printf(“cannot create fifo…\n”);

exit(1);

}

//以阻塞型只读方式打开fifo

fd=open(FIFO_NAME,O_RDONLY);

if(fd==-1)

{

printf(“open %s for read error\n”);

exit(1);

}

// 通过键盘输入字符串,再将其写入fifo,直到输入”exit”为止

r_num=read(fd,r_buf,6);

printf(” %d bytes read:%s\n”,r_num,r_buf);

unlink(FIFO_NAME);//删除fifo

}

1.写进程阻塞,读进程阻塞。

先运行写进程(被阻塞),再运行读进程,一切正常。

先运行读进程(被阻塞),再运行写进程,一切正常。

2.写进程阻塞,读进程非阻塞。

就改一句代码 fd=open(FIFO_NAME,O_RDONLY | O_NONBLOCK),下面类似。

先运行写进程(被阻塞),再运行读进程,一切正常。

先运行读进程,程序直接崩掉(Segmentation fault (core dumped)),想想也挺自然的,没东西你还要读,而且不愿等。

3.写进程非阻塞,读进程阻塞。

先运行写进程,open调用将返回-1,打开失败。

先运行读进程(被阻塞),再运行写进程,一切正常。

4.写进程非阻塞,读进程非阻塞。

其实就是上面2,3类各取一半不正常的情况。

还有我们在/tmp目录下通过ls -la命令可以看到管道文件myfifo的大小总是0,这是因为虽然FIFO文件存在于文件系统中,但FIFO中的内容都存放在内存中,所以文件大小始终为0。

本文介绍了Linux系统中有名管道(FIFO)的阻塞和非阻塞读写的方法,包括有名管道的创建、打开、读写、关闭和删除等方面。通过了解和掌握这些知识,我们可以更好地使用有名管道(FIFO)来实现进程间通信,提高系统的性能和可靠性。当然,Linux系统中有名管道(FIFO)还有很多其他的特性和用法,需要我们不断地学习和探索。希望本文能给你带来一些启发和帮助。

以上就是Linux有名管道(FIFO):一种简单而强大的进程间通信方式的详细内容,更多请关注小闻网其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。