Linux查看当前共享内存页面

本文介绍如何利用ipcs-m命令来查看系统中共享内存的状态,包括关键信息如共享内存标识符、所有者、权限等。

命令  : ipcs -m


key        shmid      owner      perms      bytes      nattch     status 


我的当前为空的

### 使用共享内存进行进程间通信 #### 创建和初始化共享内存区 为了创建并初始化一块新的共享内存区域,在 Linux 中可以使用 `shm_open` 函数来打开或创建命名的共享内存对象[^2]。 ```c #include <sys/mman.h> #include <fcntl.h> /* For O_* constants */ #include <unistd.h> int shm_fd; char *addr; // 打开/创建共享内存对象, O_CREAT | O_RDWR 表明如果不存在则创建,存在则打开用于读写 shm_fd = shm_open("/my_shm", O_CREAT | O_RDWR, 0666); if (shm_fd == -1) { perror("Failed to create shared memory object"); } ``` #### 设置共享内存量 接着设置这块新分配出来的共享内存大小。这里可以通过调用 `ftruncate()` 来完成这一操作,并指定所需的字节数作为参数传递给此函数。 ```c size_t size = 4096; // 设定共享内存大小为一页(通常为4KB) ftruncate(shm_fd, size); // 将共享内存映射到当前进程地址空间 addr = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, shm_fd, 0); if(addr == MAP_FAILED){ close(shm_fd); perror("Map failed\n"); } close(shm_fd); // 关闭描述符,因为已经通过mmap映射到了进程中 ``` #### 数据交换过程中的同步控制 由于共享内存本身并不具备任何同步机制,因此当多个进程试图同时访问同一块共享资源时可能会引发竞争条件问题。为了避免这种情况的发生,建议采用信号量(semaphore),互斥锁(mutex lock), 或者其他形式的同步原语来协调各参与方之间的交互行为[^1]。 #### 子进程与父进程间的协作模式 在一个典型的父子进程模型下,子进程负责向共享区域内写入特定的信息片段,而父进程随后会尝试从中读取这些数据。为了防止两者之间发生冲突,一般会让一方采取只写的策略,另一方执行对应的只读动作。例如: - **子进程**:仅限于修改位于页面边界之后的部分内容; - **父进程**:在整个映射完成后才开始读取消息,并且在此之前一直处于阻塞状态直到收到通知为止。 #### 清理工作 最后一步是要记得清理不再使用的共享内存段以及关联的对象句柄。这涉及到解除现有的映射关系(`munmap`) 和删除相应的文件系统入口 (`shm_unlink`)。 ```c // 解除映射 if(munmap(addr, size) == -1){ perror("Unmapping pages"); } // 删除共享内存对象 shm_unlink("/my_shm"); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值