Linux system v 共享内存

system v 共享内存

#include <sys/types.h>
#include <sys/shm.h>
int shmget(key_t key, size_t size, int shmflg);

建立:进程与共享内存的关联关系

  • key_t key:16进制的非0数字。

    一般有两种方式设置它。

    第一种:调用fotk函数

    第二章:直接使用IPC_PRIVATE

  • size:共享内存的大小
  • shmflg:
    • IPC_CREAT
    • IPC_EXCL
    • 用户,组用户,其他用户对这片内存的权限,有9个bit来表示,比如664
  • 返回值:成功返回这片共享内存的标识号;失败返回-1,errno被设置。
#include <sys/types.h>
#include <sys/shm.h>
void *shmat(int shmid, const void *shmaddr, int shmflg);
  • shmid:由shmget函数创建的,也就是shmget函数的返回值
  • shmaddr:
    • NULL:让内核去申请内存空间
    • 非NULL:自己用malloc开辟一个空间,让共享内存shmid和这个地址关联上。但是如果不是4K的整数倍,内核会向上或者向下调整。
  • shmflg:
    • SHM_RND:读写
    • SHM_RDONLY:只读
  • 返回值:
    • 成功:返回内存地址
    • 失败:返回(void *) -1
#include <sys/types.h>
#include <sys/shm.h>
int shmdt(const void *shmaddr);

取消进程与共享内存的关联关系

  • shmaddr:shmat的返回值
  • 返回值:成功0;失败-1,并设置errno。
#include <sys/types.h>
#include <sys/shm.h>
int shmctl(int shmid, int cmd, struct shmid_ds *buf);

对共享内存操作,更具cmd的不同,对共享内存进行不同的操作。

  • shmid:由shmget函数创建的,也就是shmget函数的返回值
  • cmd:
    • IPC_STAT:得到共享内存的状态
    • IPC_RMID:标记删除共享内存(当共享内存的引用计数变为0时,删除)
    • IPC_SET:设置共享内存的属性(修改权限,修改shmid等)
    • 等等
  • buf:shmid_ds结构体
  • 返回值:当cmd是IPC_RMID时:成功0;失败-1,并设置errno

用命令【ipcs】可以查看共享内存的状态

------ Shared Memory Segments --------
key        shmid      owner      perms      bytes      nattch     status
0x00007fff 65536      ys         664        256        0
0x00007ffe 98305      ys         664        256        0
0x0000555e 131074     ys         664        256        0
0x00000011 229379     ys         664        256        3
  • key:函数shmget指定的第一个参数
  • shmid:函数shmget的返回值
  • owner:属于哪个用户创建的
  • perms:这个共享内存的访问权限
  • bytes:大小
  • nattch:使用这个共享内存的进程的数量
  • status:共享内存的状态

原文地址:https://www.cnblogs.com/xiaoshiwang/p/11259093.html

时间: 2024-08-28 00:19:20

Linux system v 共享内存的相关文章

Linux IPC实践(9) --System V共享内存

共享内存API #include <sys/ipc.h> #include <sys/shm.h> int shmget(key_t key, size_t size, int shmflg); void *shmat(int shmid, const void *shmaddr, int shmflg); int shmdt(const void *shmaddr); int shmctl(int shmid, int cmd, struct shmid_ds *buf); //

细说linux IPC(五):system V共享内存

system V共享内存和posix共享内存类似,system V共享内存是调用shmget函数和shamat函数.           shmget函数创建共享内存区,或者访问一个存在的内存区,类似系统调用共享内存的open和posix共享内存shm_open函数.shmget函数原型为: #include <sys/ipc.h> #include <sys/shm.h> int shmget(key_t key, size_t size, int shmflg); key: 函

阐述linux IPC(五岁以下儿童):system V共享内存

[版权声明:尊重原创.转载请保留源:blog.csdn.net/shallnet 要么 .../gentleliu,文章学习交流,不用于商业用途] system V共享内存和posix共享内存类似,system V共享内存是调用shmget函数和shamat函数. shmget函数创建共享内存区,或者訪问一个存在的内存区,类似系统调用共享内存的open和posix共享内存shm_open函数. shmget函数原型为: #include <sys/ipc.h> #include <sys

linux进程间通信之System V共享内存详解及代码示例

共享内存是最快最为高效的进程间通信方式,当共享内存映射到共享它的某个进程的地址空间后,进程间的数据传递就不再牵扯到内核,进程可以直接读取内核,不需要通过内核系统调用进行数据拷贝.一般使用情况,从共享内存中写入或读取数据的进程间需要做同步,例如通过信号量,互斥锁去同步. 共享内存有System V 共享内存和Posix共享内存,本文介绍System V 共享内存.System V共享内存头文件及相关函数原型:#include <sys/shm.h> int shmget(key_t key, s

System V 共享内存

一 System V 共享内存的函数 1 shmget 函数 shmget(得到一个共享内存标识符或创建一个共享内存对象) 所需头文件 #include <sys/ipc.h> #include <sys/shm.h> 函数说明 得到一个共享内存标识符或创建一个共享内存对象并返回共享内存标识符 函数原型 int shmget(key_t key, size_t size, int shmflg) 函数传入值 key 0(IPC_PRIVATE):会建立新共享内存对象 大于0的32位

System V共享内存

shmread.c #include <unistd.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <sys/mman.h> #include <sys/ipc.h> #include <sys/shm.h> #include <stdlib.h> #include <stdio.h> #inc

Posix与System V共享内存函数区别

Posix标准shm_open:打开或创建一个共享内存区shm_unlink:删除一个共享内存区ftruncate:调整文件或共享内存区大小sem_open:创建信号量sem_wait:等待信号量sem_post:发送信号量sem_close:关闭信号量 System V标准ftok:生成keyshmget:建立共享内存shmdt:删除共享内存区semget:创建信号量semop:操作信号量semctl:控制信号量 简单解释一下ipcs命令和ipcrm命令.取得ipc信息:ipcs [-m|-q

system v 共享内存区

#include<sys/shm.h> int shmget(key_t key,size_t size,int oflag);    返回:成功则为共享内存区对象,出错为-1 key 的值可以是ftok的返回值,也可以是IPC_PRIVATE. ftok()               是非亲缘进程间 IPC_PRIVATE         是亲缘进程间的 size以字节为单位指定内存区的大小.当实际操作为创建一个新的共享内存区时,必须指定一个不为0的size值.如果实际操作为访问一个已存在

Linux进程间通信--mmap共享内存(一)

共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式.两个不同进程A.B共享内存的意思是,同一块物理内存被映射到进程A.B各自的进程地址空间.进程A可以即时看到进程B对共享内存中数据的更新,反之亦然.由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以. 采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝.对于像管道和消息队列等通信方式,则需要在内核和用户空间进行四次的数据拷贝,而共享内存则只拷贝两次数据[1]:一次从输入