共享内存

三、IPC结构:共享内存

每个进程内存独立的,无法直接访问。共享内存就是内核管理一段进程(物理内存),这段物理内存允许每个进程进行映射。

编程步骤:

  • 系统创建、或获取共享内存(拿到物理内存)1. ftok()\rightarrow key   2. shmget()\rightarrow 创建/获取共享内存,返回ID。
  • 挂接共享内存(映射)shmat()
  • 使用共享内存
  • 脱接共享内存(解除映射)shmdt()
  • 如果共享内存不再使用,可以删除。shmctl()

共享内存的优缺点:

  • 优点:速度最快的IPC,高效率
  • 缺点:如果有多个进程写数据,将会产生覆盖问题,导致数据的错误和不完整。

1. 函数原型:

#include <sys/ipc.h>
key_t ftok( const char *path, int id)
int shmget(key_t key,size_t size, int shmflg);


第一个参数key:为共享内存段命名,有一个特殊的键值IPC_PRIVATE,用于创建一个只属于创建进程的共享内存
第二个参数size:是共享内存的大小(字节数)
第三个参数shmflg:包含9个比特的权限标志,作用同文件操作是的mode标志位相同
返回值:函数执行成功返回一个非负整数,即内存标识符,失败时返回-1.
 

1. 测试代码:

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

int main()
{
    key_t key = ftok(".", 100); //生成key
    if (key == -1) {
        perror("ftok");
        exit(-1);
    }
    int shmid = shmget(key, 4, 0666 | IPC_CREAT | IPC_EXCL);  //创建shm
    if (shmid == -1) {
        perror("shmget");
        exit(-1);
    }
    void *p = shmat(shmid, 0, 0); //挂接共享内存
    int *pi = p;
    *pi = 1000;
    int ret = shmdt(p);  //脱接共享内存
    if (ret == -1) {
        perror("shmdt");
        exit(-1);
    }
    printf("all ok\n");
}

输出结果:

b. 测试代码:

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

int main()
{
    key_t key = ftok(".", 100); //生成key
    if (key == -1) {
        perror("ftok");
        exit(-1);
    }
    int shmid = shmget(key, 0, 0);  //创建shm
    if (shmid == -1) {
        perror("shmget");
        exit(-1);
    }
    void *p = shmat(shmid, 0, 0); //挂接共享内存
    int *pi = p;
    printf("*pi = %d\n", *pi);
    int ret = shmdt(p);  //脱接共享内存
    if (ret == -1) {
        perror("shmdt");
        exit(-1);
    }    
}

 输出结果:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值