zoukankan      html  css  js  c++  java
  • 使用共享内存实现进程间通信 shmget shmat shmctrl shmdt

    共享内存的函数有以下几个:

    (1)int shmget(key_t key, int size, int shmflg),开辟或使用一块共享内存。

    (2)void *shmat(int shmid, const void *shmaddr, int shmflg), 将参数shmid所指向的共享内存与当前进程连接。

    当使用某共享内存时,需要先使用shmat,达成连接。

    (3)int shmdt(const void *shmaddr),将先前用shmat连接的共享内存与当前进程解除连接。参数shmaddr为shmat返回的共享内存的地址。

    在完成对共享内存的使用后,需要使用shmdt解除连接。

    (4)int shmctl(int shmid, int cmd, struct shmid_ds *buf),控制内存的操作。当cmd为IPC_RMID时,删除shmid所指的共享内存。

    这些函数的表头文件为<sys/ipc.h>和<sys/shm.h>,其详细参数请去网上搜索。

    下面给出一个使用共享内存实现进程间通信的例子 :进程A开辟一块新的共享内存,进程B修改这个共享内存,进程C打印输出这个共享内存的内容,进程D删除这个共享内存。

    进程BCD运行的命令格式为:命令 共享内存ID,如./output 123432。

    进程A代码如下:

    
    
    
    

    进程B代码如下:

    
    
     
    进程C代码如下:
    
    
    
     
    进程D代码如下:
    
    
    
     
    
    
  • 相关阅读:
    【业务自动化】iTop,全面支持ITIL流程的一款ITSM工具
    【Hadoop】HDFS源码解读
    【Hadoop】Hadoop RPC框架线程模型
    电商网站项目(一)用户模块---门户
    jdk1.5后枚举类的定义规则
    回顾static与final的作用
    @Springboot搭建项目controller层接收json格式的对象失败
    把一个文件中所有文件名或者文件路径读取到一个txt文件,然后在matlab中读取
    springboot用mybatis-generator自动生成mapper和model
    hibernate、mybatis、spring data 的对比
  • 原文地址:https://www.cnblogs.com/hjslovewcl/p/2314346.html
Copyright © 2011-2022 走看看