共享内存同意两个或多个进程共享一给定的存储区,由于数据不须要来回复制,所以是最快的一种进程间通信机制。共享内存能够通过mmap()映射普通文件(特殊情况下还能够採用匿名映射)机制实现,也能够通过系统V共享内存机制实现。应用接口和原理非常easy,内部机制复杂。为了实现更安全通信,往往还与信号量等同步机制共同使用。以下主要介绍系统V共享内存机制,主要用到的系统API包含:

1.shmget函数:获得一个共享内存标识符。

int shmget(key_t key, size_t size, int flag);

key: 标识符的规则
size:共享存储段的字节数
flag:读写的权限
返回值:成功返回共享存储的id,失败返回-1

2.shmat函数:进程将共享内存连接到它的地址空间。

void *shmat(int shmid, const void *addr, int flag);

shmid:共享存储的id

addr:一般为0,表示连接到由内核选择的第一个可用地址上

flag:如前所述,一般为0        //推荐值

返回值:假设成功,返回共享存储段地址,出错返回-1

3.shmdt函数:将共享内存与进程的地址空间脱轨。

int shmdt(void *addr);

addr:共享存储段的地址,曾经调用shmat时的返回值

shmdt将使相关shmid_ds结构中的shm_nattch计数器值减1

4.shmctl函数:删除该共享内存。

int shmctl(int shmid,int cmd,struct shmid_ds *buf)

shmid:共享存储段的id

cmd:一些命令,有:IPC_STAT,IPC_RMID,SHM_LOCK,SHM_UNLOCK

请注意,共享内存不会随着程序结束而自己主动消除,要么调用shmctl删除,要么自己用手敲命令去删除,否则永远留在系统中。

一个实际样例:

server端:

/*
Write data to a shared memory segment
*/ #include<sys/types.h>
#include<sys/ipc.h>
#include<sys/shm.h>
#include<stdio.h>
#include<stdlib.h>
#include<fcntl.h>
#include<ctype.h>
#include<unistd.h> #define BUFSZ 4096 int main()
{
int shmid;
char* shmbuf;
key_t key;
char* msg;
int len; key=ftok("/tmp",0); if((shmid=shmget(key,BUFSZ,IPC_CREAT|0666))<0)
{
perror("shmget");
exit(EXIT_FAILURE);
} printf("segment created:%d\n",shmid);
system("ipcs -m"); if((shmbuf=(char*)shmat(shmid,0,0))<0)
{
perror("shmat");
exit(EXIT_FAILURE);
} msg="This is the message written to the shared memory.";
len=strlen(msg);
strcpy(shmbuf,msg); printf("%s\nTotal %d characters have written to shared memory.\n",msg,len); if(shmdt(shmbuf)<0)
{
perror("shmdt");
exit(EXIT_FAILURE);
} exit(EXIT_SUCCESS); }

client:

/*
read data from a shared memory segment
*/
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <ctype.h>
#include <unistd.h> #define BUFSZ 4096 int main(int argc, char *argv[])
{
int shmid;
char *shmbuf;
key_t key;
int len; key = ftok("/tmp", 0); if((shmid = shmget(key, 0, 0)) < 0)
{
perror("shmget");
exit(EXIT_FAILURE);
} if((shmbuf = (char *)shmat(shmid, 0, 0)) < 0)
{
perror("shmat");
exit(EXIT_FAILURE);
} printf("Info read form shared memory is:\n%s\n", shmbuf); if(shmdt(shmbuf) < 0)
{
perror("shmdt");
exit(EXIT_FAILURE);
} if(shmctl(shmid,IPC_RMID,NULL) < 0)
{
perror("shmctl");
exit(EXIT_FAILURE);
} exit(EXIT_SUCCESS);
}

linux进程通信之共享内存的更多相关文章

  1. linux 进程通信之 共享内存

    共享内存是被多个进程共享的一部分物理内存.共享内存是进程间共享数据的一种最快的方法.一个进程向共享内存区域写入了数据,共享这个内存区域的全部进程就能够立马看到当中的内容. 关于共享内存使用的API k ...

  2. Linux 进程通信(共享内存区)

    共享内存是由内核出于在多个进程间交换信息的目的而留出的一块内存区(段). 如果段的权限设置恰当,每个要访问该段内存的进程都可以把它映像到自己的私有地址空间中. 如果一个进程更新了段中的数据,其他进程也 ...

  3. Linux进程通信之共享内存实现生产者/消费者模式

    共享内存 共享内存是内核为进程创建的一个特殊内存段,它将出现在进程自己的地址空间中,其它进程可以将同一段共享内存连接(attach)到自己的地址空间.这是最快的进程间通信方式,但是不提供任何同步功能( ...

  4. linux 进程学习笔记-共享内存

    如果能划定一块物理内存,让多个进程都能将该内存映射到其自身虚拟内存空间的话,那么进程可以通过向这块内存空间读写数据而达到通信的目的.另外,和消息队列不同的是,共享的内存在用户空间而不是核空间,那么就不 ...

  5. Linux 进程通信之:内存共享(Shared Memory)(转,好文章)

    https://blog.csdn.net/afei__/article/details/84188548

  6. Linux进程通信之System V共享内存

    前面已经介绍过了POSIX共享内存区,System V共享内存区在概念上类似POSIX共享内存区,POSIX共享内存区的使用是调用shm_open创建共享内存区后调用mmap进行内存区的映射,而Sys ...

  7. 撸代码--linux进程通信(基于共享内存)

    1.实现亲缘关系进程的通信,父写子读 思路分析:1)首先我们须要创建一个共享内存. 2)父子进程的创建要用到fork函数.fork函数创建后,两个进程分别独立的执行. 3)父进程完毕写的内容.同一时候 ...

  8. linux进程间的通信之 共享内存

    一.共享内存介绍 共享内存是三个IPC(Inter-Process Communication)机制中的一个. 它允许两个不相关的进程访问同一个逻辑内存. 共享内存是在两个正在进行的进程之间传递数据的 ...

  9. 【网络编程基础】Linux下进程通信方式(共享内存,管道,消息队列,Socket)

    在网络课程中,有讲到Socket编程,对于tcp讲解的环节,为了加深理解,自己写了Linux下进程Socket通信,在学习的过程中,又接触到了其它的几种方式.记录一下. 管道通信(匿名,有名) 管道通 ...

随机推荐

  1. redis做RDB时请求超时case

        近期在排查redis做rdb时会有部分请求超时的case.初步推断是我们redisserver上开启了THP(Transparent Huge Pages).      1) Linux本身的 ...

  2. Spring3.0官网文档学习笔记(七)--3.4.2

    3.4.2 依赖与配置的细节     3.4.2.1  Straight values (primitives, Strings, and so on)     JavaBeans PropertyE ...

  3. R12 付款过程请求-功能和技术信息 (文档 ID 1537521.1)

    In this Document   Abstract   History   Details   _afrLoop=2234450430619177&id=1537521.1&dis ...

  4. Python数据结构-序表

    序表解包: list=['aa','bb','cc'] [a1,a2,a3]=list

  5. POJ 1422 Air Raid(二分图匹配最小路径覆盖)

    POJ 1422 Air Raid 题目链接 题意:给定一个有向图,在这个图上的某些点上放伞兵,能够使伞兵能够走到图上全部的点.且每一个点仅仅被一个伞兵走一次.问至少放多少伞兵 思路:二分图的最小路径 ...

  6. 求1e11以内的素数

    有两种做法,一种是打表,另一种是直接求. 打表 将1e11每隔len(len=2000w)个数字统计一下该区间内素数的个数,比如cnt[1] 表示[1,len]以内有多少个素数,cnt[2]表示[le ...

  7. Top 10 Mistakes Java Developers Make(转)

    文章列出了Java开发者最常犯的是个错误. 1.将数组转换为ArrayList 为了将数组转换为ArrayList,开发者经常会这样做: ? 1 List<String> list = A ...

  8. Android自己定义控件实战——仿淘宝商品浏览界面

    转载请声明出处http://blog.csdn.net/zhongkejingwang/article/details/38656929 用手机淘宝浏览商品详情时,商品图片是放在后面的,在第一个Scr ...

  9. Macosx Setdns

    通过C语言接口在Mac App内部对系统的DNS配置进行改动. Mac OS X设置DNS代码 演示样例代码setDNS.c内容例如以下: #include <SystemConfigurati ...

  10. 解决Android Device Chooser 找不到设备问题

    第一种情况: 已经启动了官方的模拟器也进入了Android手机界面,可是在Android Device Chooser 看不到设备,怎么办? 例如以下图所看到的,使用Reset adb 或者在adb所 ...