《unix高级环境编程》进程间通信——共享内存

共享内存是一种高效的进程间通信机制,允许进程直接访问同一内存区域。通过 shmget 创建,shmat 连接,shmdt 断开,以及 shmctl 控制,包括删除、设置权限等操作。同步访问控制是解决多进程访问冲突的关键,常使用信号量或记录锁。Linux系统提供了额外的锁定和解锁功能,但仅限超级用户。
摘要由CSDN通过智能技术生成

        共享内存是允许两个或多个进程共享同一块内存区域,并通过该区域实现数据交换的进程间通信机制。通常是由一个进程开辟一块共享内存区域,然后允许多个进程对此区域进行访问。由于不需要任何介质,而是数据由内存直接映射到进程空间,即数据不需要在客户进程和服务进程之间复制,所以共享内存是最快的 IPC 机制。共享内存必须解决多个进程之间同步访问的问题,必须控制同一时刻只允许一个进程对共享内存区域进行写入数据操作,否则会造成数据混乱。同步访问问题可以使用信号量或者记录锁进行解决。

每个共享内存都有相对应的 shmid_ds 结构,其定义如下:

/* 共享内存 */

/* shmid_ds 结构 */
struct shmid_ds
{
    struct ipc_perm shm_perm;   /* operation permission struct */
    size_t          shm_segsz;  /* size of segment in bytes */
    pid_t           shm_lpid;   /* pid of last shmop() operation */
    pid_t           shm_cpid;   /* pid of creator */
    shmatt_t        shm_nattch; /* number of current attaches */
    time_t          shm_atime;  /* last-attach time */
    time_t          shm_dtime;  /* last-detach time */
    time_t          shm_ctime;  /* last-change time */
};

共享内存创建与打开

        为了能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值