linux下有名管道进程通信
一、任务
1、学习mkfifo等函数;
2、了解有名管道的特点、阻塞打开与非阻塞打开等;
3、编写一个关于有名管道进程通信的程序,并运行。
二、相关概念
1、相关函数
创建有名管道的函数是mkfifo,函数原型是:
int mkfifo (const char *__path, __mode_t __mode)
功能:创建新的带命名路径的FIFO
参数:path — 命名管道路径
mode — 模式权限
返回值:成功返回0,失败返回-1;
2、有名管道的特点
a)、使不同进程之间完成通信。
通过mkfifo创建FIFO文件建立有名管道,
使得不同进程可以通过像访问文件的方式一样来访问有名管道,
fifo文件特点:先进先出:即写文件从有名管道数据尾端写入,数据读取从有名管道的开始处读取。
b)、有名管道内数据不支持如lseek()文件定位操作。
3、阻塞打开与非阻塞打开
对于读进程:
•若该管道是阻塞打开,且当前FIFO内没有数据,则对读进程而言将一直阻塞到有数据写入;
•若该管道是非阻塞打开,则不论FIFO内是否有数据,读进程都会立即执行读操作。即如果FIFO内没有数据,则读函数将立刻返回0、
对于写进程:
•若该管道是阻塞打开,则写操作将一直阻塞到数据可以被写入;
•若该管道是非阻塞打开而不能写入全部数据,则读操作进行部分写入或者调用失败。
三、实验代码及运行结果
1、代码
分别输入形成三个文件 mkfifo.c、client.c、service.c,代码如下:
/*mkfifo.c*/
#include"stdio.h"
#include"unistd.h"
int main()
{
int ret;
ret=mkfifo("./a.c",0777);
if(ret<0)
{
printf("creat fifo a.c failure\n");
return -1;
}
printf("creat mkfifo.c sucess\n");
return 0;
}
/*service.c*/
#include"unistd.h"
#include"fcntl.h"
#include"stdio.h"
#include"stdlib.h"
#include"string.h"
int main()
{
int fd;
char rdbuf[128]={0};
fd=open("./a.c",O_RDONLY);
if(fd<0)
{
printf("open fifo a.c failure\n");
return -1;
}
while(1)
{
read(fd,rdbuf,128);
printf("recv from fifo data:%s",rdbuf);
if(!strcmp(rdbuf,"quit\n"))
break;
memset(rdbuf,0,128);
}
sleep(1);
close(fd);
return 0;
}
/*client.c*/
#include"unistd.h"
#include"fcntl.h"
#include"stdio.h"
#include"stdlib.h"
#include"string.h"
int main()
{
int fd;
char wrbuf[128];
fd=open("./a.c",O_WRONLY);
if(fd<0)
{
printf("open fifo a.c failure\n");
return -1;
}
while(1)
{
memset(wrbuf,0,sizeof(wrbuf));
fgets(wrbuf,128,stdin);
write(fd,wrbuf,strlen(wrbuf));
if(!strcmp(wrbuf,"quit\n"))
{
break;
}
}
sleep(1);
close(fd);
return 0;
}
2、编译运行
1)、生成可执行文件
终端输入:
gcc mkfifo.c -o mkfifo
gcc service.c -o service
gcc client.c -o client
2)、运行
先运行mkfifo,终端输入: ./mkfifo
打开两个终端分别运行 service、client
终端分别输入 : ./service ./client
即可实现通信!

linux下有名管道进程通信的更多相关文章
- Linux下简单的socket通信实例
Linux下简单的socket通信实例 If you spend too much time thinking about a thing, you’ll never get it done. —Br ...
- Linux下查看某个进程打开的文件数-losf工具常用参数介绍
Linux下查看某个进程打开的文件数-losf工具常用参数介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 在linux操作系统中,一切皆文件.通过文件不仅仅可以访问常规数据,还 ...
- Linux下的管道命令有这些:
Linux下的管道命令有这些: 选取命令:cat grep 排序命令:sort wc uniq 双向重定向:tee 字符转换命令: tr, col, join, paste, expand 切割命令: ...
- windows和linux下关闭Tomcat进程
windows和linux下解决Tomcat进程 windows下启动Tomcat报错,8080端口号被占用,报错信息如下 两种解决方法,一种是关闭了这个端口号,另外一种是修改Tomcat下的serv ...
- linux下的qt串口通信
1.linux下的qt串口通信跟windows唯一的差别就是端口号的名字,windows下面是COM,而linux是ttyUSB0的路径 2.一般情况下linux插上USB转串口线就可以在/dev/目 ...
- Linux 下smi/mdio总线通信
Linux 下smi/mdio总线通信 韩大卫@吉林师范大学 下面代码描述了在用户层访问smi/mdio总线, 读写phy芯片寄存器的通用代码.Linux内核2.6以上通用. 将下面代码编译后,将可执 ...
- Linux下分析某个进程CPU占用率高的原因
Linux下分析某个进程CPU占用率高的原因 通过top命令找出消耗资源高的线程id,利用strace命令查看该线程所有系统调用 1.top 查到占用cpu高的进程pid 2.查看该pid的线程 ...
- 解决linux下tomcat停止进程任存在问题
解决linux下tomcat停止进程任存在问题 在Linux下(之所以强调linux下,是因为在windows下正常),执行tomcat ./shutdown.sh 后,虽然tomcat服务不能正常访 ...
- windows和linux下杀死Tomcat进程,解决端口占用
windows和linux下解决Tomcat进程 windows下启动Tomcat报错,8080端口号被占用,报错信息如下 两种解决方法,一种是关闭了这个端口号,另外一种是修改Tomcat下的serv ...
随机推荐
- 自写juqery插件实现左右循环滚动效果图
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xht ...
- 【dfs】p1025 数的划分
P1025 数的划分 题目描述 将整数n分成k份,且每份不能为空,任意两个方案不相同(不考虑顺序). 例如:n=7,k=3,下面三种分法被认为是相同的. 1,1,5; 1,5,1; 5,1,1; 问有 ...
- [2017-8-02]Android Learning Day9
Layout动画效果 为布局添加简单的动画效果 public class MainActivity extends AppCompatActivity { @Override protected vo ...
- hdu 2594 Simpsons’ Hidden Talents(扩展kmp)
Problem Description Homer: Marge, I just figured out a way to discover some of the talents we weren’ ...
- 商品详情页系统的Servlet3异步化实践
http://jinnianshilongnian.iteye.com/blog/2245925 博客分类: 架构 在京东工作的这一年多时间里,我在整个商品详情页系统(后端数据源)及商品详情页统一 ...
- js 判断字符串中是否包含某个字符串
String对象的方法 方法一: indexOf() (推荐) var str = "123"; console.log(str.indexOf("3") ...
- 第十四节,卷积神经网络之经典网络Inception(四)
一 1x1卷积 在架构内容设计方面,其中一个比较有帮助的想法是使用 1×1 卷积.也许你会好奇,1×1 的卷积能做什么呢?不就是乘以数字么?听上去挺好笑的,结果并非如此,我们来具体看看. 过滤器为 1 ...
- Ubuntu的 g++ gcc版本升降级
更改gcc默认版本(gcc版本降级/升级) ### 以降级到gcc-6为例 >* sudo apt install gcc-6 g++-6 >* sudo update-alternati ...
- 测试唯一ID支持多大的并发量
昨天突然考虑到这个问题,在并发比较大的情况下,你用于生成唯一ID的函数是否还能正常运行?也就是说比如我一下子进来40000个订单,你需要生成不重复的订单ID吧? 对于这个问题我以前没考虑过,但是可能是 ...
- CodeForces - 18A Triangle(数学?)
传送门 题意: 给出三个点的坐标,初始,这三个点可以构成一个三角形. 如果初始坐标可以构成直角三角形,输出"RIGNT". 如果某个点的 x或y 坐标移动一个单位后可以组成直角三角 ...