Linux培训
达内IT学院

400-111-8989

Linux学习之Linux进程间如何共享内存?


今天小编带大家看一看Linux进程间如何共享内存,对Linux感兴趣的小伙伴来看看本篇文章吧。

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

共享内存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.创建共享内存

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

2.共享内存控制

#include <sys/ipc.h> #include <sys/shm.h>

/*

*第一个参数为要操作的共享内存标识符

*第二个参数为要执行的操作

*第三个参数为shmid_ds结构的临时共享内存变量信息

*/

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

3.映射共享内存对象

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

#include <sys/types.h>

#include <sys/shm.h>

/*

*第一个参数为要操作的共享内存标识符

*第二个参数用来指定共享内存的映射地址,非0则为此参数,为0的话由系统分配

*第三个参数用来指定共享内存段的访问权限和映射条件

*/

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

4.分离共享内存对象

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

#include <sys/types.h>

#include <sys/shm.h>

/*

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

*/

int shmdt(const void *shmaddr);

共享内存在父子进程间遵循的约定

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

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

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

程序实例

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

#include

#include <sys/ipc.h>

#include <sys/shm.h>

#include <sys/types.h>

#include

#include

#define SHM_SIZE 1024

int 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 \n", ptr);

*ptr = 1004;

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

if((pid=fork()) == -1){

perror("fork Err");

exit(0);

}

else if(!pid){

printf("The Value of Child is : %d \n", *ptr);

exit(0);

}else{

sleep(1);

/*解除映射*/

shmdt(ptr);

/*删除共享内存*/

shmctl(shm_id, IPC_RMID, 0);

}

return 0;

}

输出结果:

Linux学习之Linux进程间如何共享内存?

以上就是小编今天为大家分享的Linux学习之Linux进程间如何共享内存的文章,希望本篇文章对喜欢Linux系统的小伙伴有所帮助,想要了解更多Linux相关信息,可以关注达内Linux培训官网哦。

【免责声明:本文图片及文字信息均由小编转载自网络,旨在分享提供阅读,版权归原作者所有,如有侵权请联系我们进行删除。】

预约申请免费试听课

填写下面表单即可预约申请免费试听! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

上一篇:教你从U盘上运行Linux操作系统的三种方法
下一篇:为什么Linux运维人员在IT行业越来越火?

学物联网工程好就业吗?

图像算法工程师发展前景

大数据运维工资一般多少?

运维工程师经常加班吗?

  • 扫码领取资料

    回复关键字:视频资料

    免费领取 达内课程视频学习资料

Copyright © 2023 Tedu.cn All Rights Reserved 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有

选择城市和中心
黑龙江省

吉林省

河北省

湖南省

贵州省

云南省

广西省

海南省