Linux 进程间通信 消息队列 实现两个进程间通信
例子: 通过消息队列实现两个进程间通信,一个进程从终端输入数据,通过消息队列发送,另一个进程通过消息队列接收数据
文件1 创建进程1 终端输入通过消息队列发送数据
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h> struct msgbuf //消息结构体
{
long types;
char msg[];
};
struct msgbuf mymsgbuf; //定义消息结构变量 int main(int argc, const char *argv[])
{
key_t key;
int msgid; mymsgbuf.types = ; //给消息结构赋值 key = ftok("./app",'a'); //建立key值
if(key < )
{
perror("ftok fail ");
exit();
} // 创建消息队列,如果消息队列存在,errno 会提示 eexist
// 错误,此时只需要直接打开消息队列即可
msgid = msgget(key,IPC_CREAT|IPC_EXCL|);
if(msgid < )
{
if(errno == EEXIST) //文件存在错误提示
{
msgid = msgget(key,);//打开消息队列
}
else //其他错误退出
{
perror("msgget fail ");
exit();
}
}
while() //循环从终端获取数据,然后通过消息队列发送出去,输入 “quit” 结束循环
{
fgets(mymsgbuf.msg, , stdin); //终端获取消息写入消息队列中
//发送消息
msgsnd(msgid, &mymsgbuf, sizeof(mymsgbuf)-sizeof(long),);
if(strstr(mymsgbuf.msg, "quit")!=NULL)
{
break;
}
} //删除消息队列
msgctl(msgid, IPC_RMID, NULL); return ;
}
文件 2 创建进程2 ,接收消息队列的数据,打印到终端上
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/msg.h>
#include <string.h> struct msgbuf //消息结构体
{
long types;
char b[];
};
struct msgbuf mymsgbuf, recvbuf; //定义消息结构变量 int main(int argc, const char *argv[])
{
key_t key;
int msgid; mymsgbuf.types = ; //给消息结构赋值 key = ftok("./app",'a'); //建立key值
if(key < )
{
perror("ftok fail ");
exit();
} // 创建消息队列,如果消息队列存在,errno 会提示 eexist
// 错误,此时只需要直接打开消息队列即可
msgid = msgget(key,IPC_CREAT|IPC_EXCL|);
if(msgid < )
{
if(errno == EEXIST) //文件存在错误提示
{
msgid = msgget(key,);//打开消息队列
}
else //其他错误退出
{
perror("msgget fail ");
exit();
}
} while() //接收到 “quit” 结束循环
{
//接收消息
msgrcv(msgid,&recvbuf,sizeof(mymsgbuf)-sizeof(long),,); //recvbuf 是接收消息的结构体,其中的b是实际的数据
if(strstr(recvbuf.b, "quit") != NULL)
{
break;
}
printf("recvbuf: %s", recvbuf.b); //
} //删除消息队列
msgctl(msgid, IPC_RMID, NULL); return ;
}
测试:
Linux 进程间通信 消息队列 实现两个进程间通信的更多相关文章
- PHP 进程间通信——消息队列(msg_queue)
PHP 进程间通信--消息队列 本文不涉及PHP基础库安装.详细安装说明,请参考官网,或期待后续博客分享. 1.消息队列函数准备 <?php//生成一个消息队列的key$msg_key = ft ...
- Linux进程间通信-消息队列(mqueue)
前面两篇文章分解介绍了匿名管道和命名管道方式的进程间通信,本文将介绍Linux消息队列(posix)的通信机制和特点. 1.消息队列 消息队列的实现分为两种,一种为System V的消息队列,一种是P ...
- Linux下进程间通信--消息队列
消息队列的定义遍地都是,不想移驾,请看下文: 一.定义: 消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法. 每个数据块都被认 为是有一个类型,接收者进程接收的数据块可以有不同的类型值.我 ...
- Linux进程间通信—消息队列
四.消息队列(Message Queue) 消息队列就是消息的一个链表,它允许一个或者多个进程向它写消息,一个或多个进程向它读消息.Linux维护了一个消息队列向量表:msgque,来表示系统中所有的 ...
- 详解linux进程间通信-消息队列
前言:前面讨论了信号.管道的进程间通信方式,接下来将讨论消息队列. 一.系统V IPC 三种系统V IPC:消息队列.信号量以及共享内存(共享存储器)之间有很多相似之处. 每个内核中的 I P C结构 ...
- linux进程间通信-消息队列
一 消息队列的介绍 消息队列提供了一种从一个进程向另一个进程发送一个数据块的方法. 每个数据块都被认为含有一个类型,接收进程可以独立地接收含有不同类型的数据结构. 我们可以通过发送消息来避免命名管道的 ...
- linux进程间通信消息队列:msgsnd: Invalid argument
今天写了个消息队列的小测试程序结果send端程序总是出现:msgsnd: Invalid argument,搞了半个小时也没搞明白,后来查资料发现我将(st_msg_buf.msg_type = 0; ...
- Linux 进程间通信 消息队列
1.特点: 消息队列是IPC对象的一种 消息队列由消息队列ID来唯一标识 消息队列就是一个消息的列表.用户可以在消息队列中添加消息.读取消息等. 消息队列可以按照类型来发送/接收消息(消息的类型是正整 ...
- 进程间通信消息队列msgsnd执行:Invlid argument——万恶的经验主义
最近在搞进程间通信,首先在我的ubuntu 14.04上写了接口和测试demo,编译和执行都OK,,代码如下: 接口文件ipcmsg.h /* ipcmsg.h */ #ifndef H_MSGIPC ...
随机推荐
- python2和python3中int整型数据的不同之处
python2中的除法,结果为整型数字(int型),例如 10/5=2,10/3=3,小数位向下取整 python3中的除法,结果为浮点型数字(float型)结果小数位最多保留16位小数
- 27-python基础-python3-异常处理(try except)
到目前为止,在 Python 程序中遇到错误,或“异常”,意味着整个程序崩溃.不希望这发生在真实世界的程序中. 相反,希望程序能检测错误,处理它们,然后继续运行. 实例1: 当试图用一个数除以零时 ...
- ARM 汇编与C之间 的调用
一. 汇编调用 C 1. 初始化栈 2. 初始化BSS段 (BSS 段是C语言存放未初始化的全局变量,或者初始化为0 的全局变量) 3 .使用 r0 ,r1, r2, r3 给函数传参,如果多于 4 ...
- 【LeetCode】贪心
[452] Minimum Number of Arrows to Burst Balloons [Medium] 给一堆线段,使用最少的arrow,穿过所有的线段.陈题,第一条线段的终点. Inpu ...
- h5开发与pc开发的差异性
1. viewport 将layout viewport 设置成ideal viewport . width=device-width,也可以设置 initial-scale=1,最好两者都有. wi ...
- Delphi 窗体函数 ShowScrollBar 控制滚动条
API函数 函数来源:FUNCTION ulong ShowScrollBar(ulong hwnd,ulong wBar,ulong bShow) LIBRARY "user32.dll& ...
- 每天一个Linux命令:ls(1)
ls ls命令用于显示指定工作目录下之内容(列出目前工作目录所含之文件及子目录). 格式 ls [-alrtAFR] [name...] 参数选项 参数 备注 -a 列出目录下的所有文件,包括以 . ...
- webpack 添加eslint代码审查
1). 添加包 npm install eslint --save-dev npm install eslint-loader --save-dev npm install eslint-plugin ...
- Hbase的读写流程
HBase读写流程 1.HBase读数据流程 HRegionServer保存着meta表以及表数据,要访问表数据,首先Client先去访问zookeeper,从zookeeper里面获取meta表所在 ...
- js设计模式——3.观察者模式
js设计模式——观察者模式 /*js设计模式——.观察者模式*/ // 主题,保存状态,状态变化之后触发所有观察者对象 class Subject { constructor() { this.sta ...