1.软文推荐

2.软文推荐

3.软文推荐

共享内存就是允许两个或多个进程共享一定的存储区。就如同 malloc() 函数向不同进程返回了指向同一个物理内存区域的指针。当一个进程改变了这块地址中的内容的时候,其它进程都会察觉到这个更改,下面为大家详细讲解一下Linux系统进程共享内存。

u=1876768233,2041829256&fm=26&gp=0
共享内存 IPC 原理

共享内存进程间通信机制主要用于实现进程间大量的数据传输,下图所示为进程间使用共享内存实现大量数据传输的示意图:

Linux进程间如何共享内存Linux进程间如何共享内存

共享内存是在内存中单独开辟的一段内存空间,这段内存空间有自己特有的数据结构,包括访问权限、大小和最近访问的时间等。该数据结构定义如下:

from /usr/include/linux/shm.h

struct shmid_ds {
struct ipc_perm shm_perm; /* operation perms 操作权限 */
int shm_segsz; /* size of segment (bytes) 段长度大小 */
__kernel_time_t shm_atime; /* last attach time 最近attach时间 */
__kernel_time_t shm_dtime; /* last detach time 最近detach时间 */
__kernel_time_t shm_ctime; /* last change time 最近change时间 */
__kernel_ipc_pid_t shm_cpid; /* pid of creator 创建者pid */
__kernel_ipc_pid_t shm_lpid; /* pid of last operator 最近操作pid */
unsigned short shm_nattch; /* no. of current attaches */
unsigned short shm_unused; /* compatibility */
void *shm_unused2; /* ditto - used by DIPC */
void *shm_unused3; /* unused */
};

两个进程在使用此共享内存空间之前,需要在进程地址空间与共享内存空间之间建立联系,即将共享内存空间挂载到进程中。

系统对共享内存做了以下限制:

#define SHMMAX 0x2000000 /* max shared seg size (bytes) 最大共享段大小 */
#define SHMMIN 1 /* min shared seg size (bytes) 最小共享段大小 */
#define SHMMNI 4096 /* max num of segs system wide */
#define SHMALL (SHMMAX/getpagesize()*(SHMMNI/16))
#define SHMSEG SHMMNI /* max shared segs per process */
Linux 共享内存管理

1.创建共享内存

#include  #include 

/* * 第一个参数为 key 值,一般由 ftok() 函数产生 * 第二个参数为欲创建的共享内存段大小(单位为字节) * 第三个参数用来标识共享内存段的创建标识 */

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

2.共享内存控制

#include  #include 

/* * 第一个参数为要操作的共享内存标识符 * 第二个参数为要执行的操作 * 第三个参数为 shmid_ds 结构的临时共享内存变量信息 */

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

3.映射共享内存对象

系统调用 shmat() 函数实现将一个共享内存段映射到调用进程的数据段中,并返回内存空间首地址,其函数声明如下:

#include 
#include 

/* * 第一个参数为要操作的共享内存标识符 * 第二个参数用来指定共享内存的映射地址,非0则为此参数,为0的话由系统分配 * 第三个参数用来指定共享内存段的访问权限和映射条件 */

void *shmat(int shmid, const void *shmaddr, int shmflg);

4.分离共享内存对象

在使用完毕共享内存空间后,需要使用 shmdt() 函数调用将其与当前进程分离。函数声明如下:

#include #include 

/* * 参数为分配的共享内存首地址 */

int shmdt(const void *shmaddr);
共享内存在父子进程间遵循的约定

1.使用 fork() 函数创建一个子进程后,该进程继承父亲进程挂载的共享内存。

2.如果调用 exec() 执行一个新的程序,则所有挂载的共享内存将被自动卸载。

3.如果在某个进程中调用了 exit() 函数,所有挂载的共享内存将与当前进程脱离关系。

程序实例

申请一段共享内存,父进程在首地址处存入一整数,子进程读出。

#include#include #include #include #include#include#define SHM_SIZE 1024int main(){int shm_id, pid;int *ptr = NULL;

/* 申请共享内存 */

shm_id = shmget((key_t)1004, SHM_SIZE, IPC_CREAT | 0600);

/* 映射共享内存到进程地址空间 */

ptr = (int*)shmat(shm_id, 0, 0);

printf("Attach addr is %p 
", ptr);

*ptr = 1004;

printf("The Value of Parent is : %d 
", *ptr);

if((pid=fork()) == -1){
perror("fork Err");
exit(0);
}
else if(!pid){
printf("The Value of Child is : %d 
", *ptr);
exit(0);
}else{
sleep(1);

/* 解除映射 */

shmdt(ptr);

/* 删除共享内存 */

shmctl(shm_id, IPC_RMID, 0);
}

return 0;
}

输出结果:

Linux进程间如何共享内存Linux进程间如何共享内存

本文来源:www.lxlinux.net/4317.html,若引用不当,请联系修改。

相关文章 8

1

分享一下DOM在Ahooks中的处理过程 3分钟前

一个优秀的工具库应该有自己的一套输入输出规范,一来能够支持更多的场景,二来可以更好的在内部进行封装处理,三来使用者能够更加...

2

企业免费云服务器(免费企业云服务平台) 5分钟前

目录:1、主机免费云服务器如何2、有什么好的免费云服务器?3、免费的云服务器有哪些主机免费云服务器如何 1.艾比云 从2001年开始提供免...

3

Linux系统执行bin文件 8分钟前

Linux系统中如何执行.bin?本篇文章将为大家分享一下Linux系统执行bin文件的方法,有需要的小伙伴可以参考一下。 什么是 .bin 文件? .bin 文...

4

Ubuntu与Windows双系统时间不同步解决方案 10分钟前

不知道有没朋友跟我一样是 Ubuntu 和 Windows 双系统?今天有朋友问到我,当他从 Ubuntu 系统重新启动到 Windows 时,会发现 Windows 中的时间变了...

6

docker迁移数据目录具体方法 12分钟前

本篇文章重点为大家讲解一下docker迁移数据目录具体方法,有需要的小伙伴可以参考一下。 查看磁盘使用 #du-hs/var/lib/docker/ 237G/var/lib/docke...

7

南昌seo推广优化方案价格(南昌seo如何做) 14分钟前

目录:1、整站优化价格大概是多少啊?  2、SEO优化一个网站需要多少费用3、网站seo优化要多少钱?4、SEO优化一般都多少钱?整站优化价格...

8

Linux ss命令 16分钟前

Linux系统中ss命令用于获取 socket 统计信息,它显示的内容和 netstat 类似,但是ss命令更快,够显示更多更详细的有关 TCP 和连接状态的信息,...