一、何谓共享内存?

共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式。两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以。

二:共享内存的使用

1. 创建共享内存(打开)

#include <sys/ipc.h>
#include <sys/shm.h>
int shmget(key_t key,size_t size,int shmflg>;key(非0整数):为共享内存段命名,shmget成功时返回一个与key相关的内存标识符shm_id(非负整数),失败时返回-1size:以字节为单位指定需要共享的内存容量shmflg:权限标志,与open函数的mode参数一样,创建共享内存时此参数位可写成
 IPC_CREAT | 0666
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

2.启动进程对共享内存的访问(映射) 
第一次创建完共享内存时,它还不能被任何进程访问,shmat函数的作用就是用来启动对该共享内存的访问,并把共享内存连接到当前进程的地址空间。

#include<sys/types.h>
#include <sys/shm.h>
void *shmat(int shm_id, const void *shm_addr, int shmflg);shm_id: 是由shmget 函数返回的共享内存标识。shm_addr:指定共享内存连接到当前进程的地址位置,通常为空,表示让系统来选择共享内存的地址。shm_flg:是一组标志位,通常为0。
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

shmat 调用成功后返回一个指向共享内存第一个字节的指针,调用失败返回-1。

3、分离共享内存(解除映射) 
shmdt函数用于将共享内存从当前进程中分离。注意,将共享内存分离并不是删除它,只是使该共享内存对当前进程不再可用。

#include <sys/types.h>
#include <sys/shm.h>int shmdt(const void *shmaddr);shmaddr:是shmat函数返回的地址指针
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

调用成功返回0,失败返回-1。 
4、控制共享内存(控制)

#include <sys/ipc.h>
#include <sys/shm.h>int shmctl(int shm_id, int command, struct shmid_ds *buf);shm_id:是shmget函数返回的共享内存标识符command: 控制共享内存要采取的操作,可以取以下三个值:
IPC_STAT : 把shmid_ds结构体中的数据设置为共享内存的当前关联值,即用共享内存的当前关联值覆盖shmid_ds的值
IPC_SET : 如果进程有足够的权限,就把共享内存当前的关联值设置为shmid_ds结构体中给出的值
IPC_RMID : 删除共享内存段buf : 是一个结构体指针,指向共享内存模式和访问权限的结构体
shmid_ds结构体的成员至少包括:
struct shmid_ds
{uid_t shm_perm.uid;uid_t shm_perm.gid;mode_t shm_perm.mode;};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

调用成功返回0,失败返回-1

三:编写共享内存代码

一般对内存区域的操作是先打开-》映射-》(操作)-》(控制)-》解除映射。 
shm.h

#ifndef _SHM_
#define _SHM_#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/wait.h>
#include <unistd.h>#define _PATH_ "."
#define _PROJECT_ 8888
#define _SHM_SIZE_ 4*1024int get_shm();
char *at_shm();
int delete_shm();
int rm_shm();
#endif
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

shm.c

#include "shm.h"int get_shm()
{key_t key = ftok(_PATH_,_PROJECT_);int flag = IPC_CREAT | 0666;int shm_id = shmget(key,_SHM_SIZE_,flag);if(shm_id ==-1){printf("shmget error\n");}else{printf("shmget success\n");}return shm_id;
}
char *at_shm(int shm_id)
{return (char*)shmat(shm_id,NULL,0);
}
int delete_shm(char* addr)
{return shmdt(addr);
}
int rm_shm(int shm_id)
{return shmctl(shm_id,IPC_RMID,NULL);
}int main()
{int shm_id = get_shm();//创建新进程pid_t id= fork();if(id<0){printf("fork error\n");return 1;}else if(id==0){//childchar *buf = at_shm(shm_id);int i = 0;while(i<4096){buf[i]= 'w';i++;}buf[4096]= '\0';delete_shm(buf);}else{//fatherchar *buf = at_shm(shm_id);sleep(3);printf("%s\n",buf);waitpid(id,NULL,0);rm_shm(shm_id);}return 0;
}

IPC--三---共享内存相关推荐

  1. 进程间通信IPC之--共享内存

    每个进程各自有不同的用户地址空间,任何一个进 程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲 区,进程1把数据从用户空间拷到内核缓冲区,进程2再从内核缓冲 ...

  2. System V IPC之共享内存

    共享内存是一种最为高效的进程间通信方式,进程可以直接读写内存, 而不需要任何数据的拷贝 共享内存在内核空间创建, 可以被进程映射到用户空间访问 由于多个进程可同时访问共享内存 , 因此需要同步和互斥机 ...

  3. linux ipc shmget 例子,Linux IPC之共享内存C 事例(示例代码)

    简介 共享内存(shared memory)是最简单的Linux进程间通信方式之一.使用共享内存,不同进程可以对同一块内存进行读写.由于所有进程对共享内存的访问就和访问自己的内存空间一样,而不需要进行 ...

  4. linux学习---基于内存的IPC(共享内存,信号量数组,消息队列)

    常用的IPC分为两个类别,一是基于文件,而是基于内存 基于文件的分别有匿名管道,有名管道,普通的文件共享,socket文件 如果要看基于文件的IPC,请参考:http://blog.csdn.net/ ...

  5. IPC(进程间通信) | 共享内存

    文章目录 共享内存 共享内存函数 shmget函数 shmat函数 shmdt函数 shmctl函数 示例1(未使用信号量同步版本) 示例2(使用信号量同步版本) 共享内存的特点 共享内存 共享内存区 ...

  6. Linux 18 IPC之共享内存shm

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

  7. java 共享内存ipc_进程间通信——IPC之共享内存

    共享内存是三个IPC机制中的一个.它允许两个不相关的进程访问同一个逻辑内存.共享内存是在两个正在进行的进程之间传递数据的一种非常有效的方式. 大多数的共享内存的实现,都把由不同进程之间共享的内存安排为 ...

  8. linux 共享内存函数封装,linux ftok()函数 --多进程IPC之共享内存

    系统创建IPC通信(如消息队列.共享内存时)必须指定一个ID值.一般状况下,该id值经过ftok函数获得. ftok原型以下: key_t ftok( char * fname, int id ) f ...

  9. 【Linux 应用编程】进程管理 - 进程间通信IPC之共享内存 mmap

    IPC(InterProcess Communication,进程间通信)是进程中的重要概念.Linux 进程之间常用的通信方式有: 文件:简单,低效,需要代码控制同步 管道:使用简单,默认阻塞 匿名 ...

  10. 专题 14 IPC之共享内存

    1.概述 共享内存是在多个进程之间共享内存区域的一种进程间的通信方式,它是在多进程之间对内存段进行映射的方式实现内存共享的.这是IPC最快捷的方式,共享内存方式的通信过程没有中间过程,共享内存直接将某 ...

最新文章

  1. SSAS : 如何禁用SSAS的QueryLog
  2. CPU、GPU、FPGA、ASIC等AI芯片特性及对比
  3. Oracle数据库案例整理-Oracle系统执行时故障-Shared Pool内存不足导致数据库响应缓慢...
  4. 手写文字识别java_java 手写文字图片识别提取 百度API
  5. 小爱音箱mini系统故障怎么办_梦龙评机小米小爱音箱HD使用体验
  6. sqlserver自定义函数
  7. 【转】乐观锁和悲观锁的区别
  8. 基于Tight VNC的远程协助功能的实现
  9. 2.windows-and-mac在控制台创建ASP.NET-Core应用程序
  10. PMP第十三章:项目相关方管理
  11. windos开启IIS管理器
  12. 一文读懂长非编码RNA(lncRNA)的分类、功能及测序鉴定方法
  13. osm数据导入mysql_利用OpenStreetMap(OSM)数据搭建一个地图服务
  14. 《操作系统真象还原》——0.25 指令集、体系结构、微架构、编程语言
  15. 简单七个步骤写一份策划方案(上)
  16. [注塑]各种进胶方式优缺点分析
  17. 活动预告:专访Velo,跨境金融的商业落地探索 | TI对话首席
  18. LightOJ 1079 Just another Robbery
  19. Python 国务院政策爬虫(附完整代码)+自动更新+写入数据库
  20. MySQL自动化安装脚本-python版

热门文章

  1. JAVA NIO知识点总结(2)——直接缓冲区和非直接缓冲区
  2. bzoj 1914: [Usaco2010 OPen]Triangle Counting 数三角形——极角排序
  3. C#设计模式——生成器模式(Builder Pattern)
  4. 策略模式、上下文与内部类的思考
  5. 牛客多校6 - Harmony Pairs(数位dp)
  6. HDU - 6598 Harmonious Army(最大流最小割)
  7. ZOJ - 2706 Thermal Death of the Universe(线段树)
  8. YOLO目标检测算法
  9. python爬虫-爬取壁纸酷主页内容
  10. python高级语法-GUI编程(主要介绍tkinter)