三种IPC这就是所谓的XSI IPC,每间:

  • 消息队列
  • 信号量
  • 共享存储器
以下分别介绍三种IPC的使用方法。

1、消息队列
消息队列是消息的链接表,具有例如以下函数接口:
  • msgget:创建一个新队列或打开一个现存的队列。
  • msgsnd:将消息加入到队列尾端。
  • msgrcv:从队列中取消息。
我们能够自行定义一个表示消息的结构体,它由类型字段和实际数据组成:
struct mest_t {
long type; // 消息类型
char text[512]; // 消息内容
};

有了消息类型。当我们用msgrcv函数取消息时,就不一定要以先进先出的顺序,而是能够依据消息类型取消息了。以下是一段简单的測试代码:
#include <stdio.h>
#include <sys/msg.h>
#include <sys/types.h>
#include <string.h>
#include <errno.h> struct mest_t {
long type;
char text[512];
}; int main(void)
{
pid_t pid;
int mq_id;
struct mest_t msg; /* IPC_PRIVATE用于创建一个新队列
* 设置了IPC_EXCL而且设置了IPC_CREAT。当文件存在时返回错误
*/
mq_id = msgget(IPC_PRIVATE, IPC_CREAT | IPC_EXCL);
if (mq_id == EEXIST)
return -1; /* 返回EEXIST表示IPC已存在 */ if ((pid = fork()) < 0)
return -1;
else if (pid == 0)
{
/* 子进程 */
msg.type = 123; /* 消息类型 */
strcpy(msg.text, "Hello world!"); /* 消息内容 */ /* 非堵塞方式将消息放入消息队列
* 队列已满则返回EAGAIN
*/
while (msgsnd(mq_id, (long *)&msg, 512, IPC_NOWAIT) == EAGAIN)
sleep(1);
}
else
{
/* 非堵塞方式从队列中取消息
* 假设没有指定类型的消息。函数返回-1,errno设置为ENOMSG
*/
while (msgrcv(mq_id, (long *)&msg, 512, 123, IPC_NOWAIT) == -1)
{
if (errno == ENOMSG)
{
printf("There is no this type message!\n");
sleep(1);
}
} printf("%s\n", msg.text);
} return 0;
}

当父进程须要取的消息类型和子进程发送的消息类型同样时。执行结果例如以下:


父进程可以非常快接收到子进程发送到消息队列中的消息。

可是改动msgrcv的消息类型參数后,执行结果例如以下:



父进程得不到想要的消息,一直打印错误信息。

2、信号量
信号量是一个计数器。用于多进程对共享数据对象的訪问。步骤例如以下:
  • 測试控制该资源的信号量。
  • 若此信号量的值为正。则进程能够使用该资源。进程将信号量值减1,表示它使用了一个资源单位。
  • 若此信号量的值为0。则进程进入休眠状态,直至信号量大于0。进程被唤醒后。它返回至第一步。
当进程不再使用由一个信号量控制的共享资源时,该信号量值增1。假设有进程正在休眠等待此信号量,则唤醒它们。

3、共享存储
共享存储同意多个进程共享一块给定的存储区。是最快的一种IPC。測试代码例如以下:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/shm.h> #define SHM_SIZE 100
#define SHM_MODE (SHM_W | SHM_R | IPC_CREAT) int main()
{
int shmid;
char *shmptr;
pid_t pid; /* 获得共享存储标识符 */
if ((shmid = shmget(IPC_PRIVATE, SHM_SIZE, SHM_MODE)) < 0)
return -1; if ((pid = fork()) < 0)
return -1;
else if (pid == 0)
{
shmptr = shmat(shmid, 0, 0); /* 參数2为0表示由内核分配共享空间 */
printf("Child attached shared memory is : %lx\n", (unsigned long)shmptr);
shmdt(shmptr); /* 使进程脱离该共享空间 */
}
else
{
waitpid(pid, NULL, 0); shmptr = shmat(shmid, 0, 0);
printf("Parent attached shared memory is : %lx\n", (unsigned long)shmptr);
shmdt(shmptr); shmctl(shmid, IPC_RMID, 0); /* 删除该共享存储段 */
} return 0;
}

执行结果:



从上面的实验结果能够看出,父、子进程共享了同一个存储段。

有一点须要注意,shmdt函数仅仅是让进程脱离该共享存储段,但该存储段依旧存在而且shmid依旧有效。它是与shmat相相应的。而还有一个函数shmctl使用IPC_RMID參数时才是真正删除该共享段。


共享存储段和存储映射I/O中的mmap函数很相似,它们之间的差别是:mmap映射的存储段是与文件相关联的,XSI共享存储段则并无这样的关联。

参考:
《unix编程环境》 P415-P432.

【Linux计划】XSI IPC的更多相关文章

  1. linux进程间通信-XSI IPC

    一 什么是XSI IPC     有三种 IPC我们称作XSI IPC,即消息队列.信号量以及共享存储器(共享内存),它们之间有很多相似之处. 二 标识符和键     每个内核中的 IPC结构(消息队 ...

  2. 进程间通信之XSI IPC

    XSI IPC源自于系统V的IPC功能. 有三种IPC我们称作XSI IPC,即消息队列.信号量以及共享存储器,它们之间有很多相似之处. 1.标识符和键 每个内核中的IPC结构(消息队列.信号量或共享 ...

  3. 进程间通信——XSI IPC之消息队列

    进程间通信XSI IPC有3种:消息队列.共享内存.信号量.它们之间有很多相似之处,但也有各自的特殊的地方.消息队列作为其中比较简单的一种,它会有些什么东西呢,来一起探讨探讨.. 消息队列结构 消息队 ...

  4. Linux ns 5. IPC Namespace 详解

    文章目录 1. 简介 2. 源码分析 2.1 copy_ipcs() 2.2 ipcget() 2.3 ipc_check_perms() 2.4 相关系统调用 参考文档: 1. 简介 进程间通讯的机 ...

  5. linux下六大IPC机制【转】

    转自http://blog.sina.com.cn/s/blog_587c016a0100nfeq.html linux下进程间通信IPC的几种主要手段简介: 管道(Pipe)及有名管道(named ...

  6. Linux计划任务Crontab实例详解教程

    说明:Crontab是Linux系统中在固定时间执行某一个程序的工具,类似于Windows系统中的任务计划程序 下面通过详细实例来说明在Linux系统中如何使用Crontab 操作系统:CentOS ...

  7. Linux计划任务(转载)

    Linux计划任务(转载) Linux的计划任务是系统管理方面的一个重要内容,是系统自动完成工作的一种实现方式,正因为有了计划任务,我们才可以完全实现系统管理的脚本化和自动化. 关于计划任务,Linu ...

  8. Linux 计划任务总结

    今天项目用到了,Linux计划任务,从网上找了基本blog看了,总结了下. Linux 下的计划任务有atd和crond两种计划任务.atd服务使用的at命令只能执行一次,而crond服务使用的cro ...

  9. Linux. 计划任务 时间格式

    Linux. 计划任务 时间格式 在linux中执行指令:cat /etc/crontab 结果,如下图所示: 结果一目了然,不多说. 如有问题,欢迎纠正!!! 如有转载,请标明源处:https:// ...

随机推荐

  1. 基于Maven,Spring+ActiveMQ实现,贴近实际

    本文只实现了Topic,queue改点配置就行了 一.pom依赖 Spring的太长了,具体可以看下面源码里面 <dependency> <groupId>org.apache ...

  2. jquery-11 如何实现标签的鼠标拖动效果

    jquery-11 如何实现标签的鼠标拖动效果 一.总结 一句话总结:核心原理:1.标签实现绝对定位,位置的话跟着鼠标走.2.点击标签的话,给标签绑定事件,停止按住鼠标的话,解除绑定的事件. 1.事件 ...

  3. 【9201】&&【a201】明明的随机数

    Time Limit: 10 second Memory Limit: 2 MB 问题描述 明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整 ...

  4. 【38.24%】【POJ 1201】Intervals

    Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 25902 Accepted: 9905 Description You are ...

  5. 【codeforces 742B】Arpa’s obvious problem and Mehrdad’s terrible solution

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  6. AE指定字段转成注记

    转自原文 ae指定字段转成注记 ArcMap中有一个功能是Label Features,就是可以将图层内指定字段值显示以Label形式显示在主窗口上,在Label Features后,用右键点击图层, ...

  7. 【u016】无序字母对

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 给定n个各不相同的无序字母对(区分大小写,无序即字母对中的两个字母可以位置颠倒).请构造一个有n+1个 ...

  8. 【76.83%】【codeforces 554A】Kyoya and Photobooks

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  9. 支付宝开发之手机网站支付(H5支付)

    其实官方的文档中:https://docs.open.alipay.com/203 介绍的已经很详细了,我就实地的看文档操作了一遍,具体步骤如下: 一.创建应用 流程如下: 首先要有支付宝开放平台: ...

  10. 接入Erlang控制台的几种方法

    在window中调试的时候我们可以通过启动多个cmd窗口运行Erlang节点,在生产环境中我们需要Erlang服务在Centos服务器上后台运行;这就需要在启动的时候添加启动参数detached来脱离 ...