当前位置: 首页 > news >正文

【项目 进程13】2.28共享内存(1) 2.29共享内存(2)

文章目录

    • 2.28共享内存(1)
      • 共享内存(效率最高,比内存映射更高。因为内存映射还需一个文件做载体)
      • 共享内存使用步骤
      • 共享内存操作函数
      • 头文件
    • 2.29共享内存(2)
      • 共享内存相关问题
      • 共享内存和内存映射的区别
      • 通过共享内存实现进程间通信
      • 共享内存操作命令


2.28共享内存(1)

共享内存(效率最高,比内存映射更高。因为内存映射还需一个文件做载体)

在这里插入图片描述
在这里插入图片描述
IPC:Inter-Process Communication 进程间通信

新的问题:两个进程同时写数据,一个进程读数据,涉及进程同步问题。

共享内存使用步骤

在这里插入图片描述shm:share memory
at:attach (在虚拟内存的用户区 的 共享区 ;内存映射也在这里)
dt:detach
ctl:control

分离和销毁是不同的。

共享内存操作函数

在这里插入图片描述

头文件

#include <sys/ipc.h>
#include <sys/shm.h>
  • shmget

在这里插入图片描述

  • shmat
    在这里插入图片描述

  • shmdt
    在这里插入图片描述
    shmaddr是虚拟地址空间刚刚绑定的地址。

  • shmctl
    在这里插入图片描述第三行 :的进程
    IPC_RMID:只是标记共享内存需要被删除。要到没有进程和这块内存绑定了,这块共享内存才会被真的删除

buf:需要的操作cmd不同,buf的作用不同。在标记销毁的时候,buf没有用,所以直接置NULL就可以。

  • ftok
    在这里插入图片描述
    如果有很多的key记不过来,可以用这个。名字比身份证号好记

2.29共享内存(2)

共享内存相关问题

在这里插入图片描述

共享内存和内存映射的区别

在这里插入图片描述

通过共享内存实现进程间通信

共享内存写数据

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>int main() {    // 1.创建一个共享内存int shmid = shmget(100, 4096, IPC_CREAT|0664);printf("shmid : %d\n", shmid);// 2.和当前进程进行关联void * ptr = shmat(shmid, NULL, 0);char * str = "helloworld";// 3.写数据memcpy(ptr, str, strlen(str) + 1);printf("按任意键继续\n");getchar();// 4.解除关联shmdt(ptr);// 5.删除共享内存shmctl(shmid, IPC_RMID, NULL);return 0;
}

共享内存读数据

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <string.h>int main() {    // 1.获取一个共享内存int shmid = shmget(100, 0, IPC_CREAT);printf("shmid : %d\n", shmid);// 2.和当前进程进行关联void * ptr = shmat(shmid, NULL, 0);// 3.读数据printf("%s\n", (char *)ptr);printf("按任意键继续\n");getchar();// 4.解除关联shmdt(ptr);// 5.删除共享内存shmctl(shmid, IPC_RMID, NULL);return 0;
}

共享内存操作命令

在这里插入图片描述
ipcs -m 用比较多

在这里插入图片描述被标记销毁以后,key被置0,但是因为还有绑定,所以暂时还没被销毁。直到所有绑定都解除,ipcs -m就查不到它了
在这里插入图片描述

http://www.lryc.cn/news/107585.html

相关文章:

  • Flask框架-流量控制:flask-limiter的使用
  • 【机器学习】西瓜书习题3.5Python编程实现线性判别分析,并给出西瓜数据集 3.0α上的结果
  • Elasticsearch:通过动态修剪实现更快的基数聚合
  • Webpack5 生产模式压缩图片ImageMinimizerPlugin
  • 时序预测 | Matlab实现基于BP神经网络的电力负荷预测模型
  • 基于回溯算法实现八皇后问题
  • Linux【网络编程】之深入理解TCP协议
  • 如何克服看到别人优于自己而感到的焦虑和迷茫?
  • 浅谈React中的ref和useRef
  • Linux C 获取主机网卡名及 IP 的几种方法
  • 解密外接显卡:笔记本能否接外置显卡?如何连接外接显卡?
  • list与erase()
  • Arcgis 分区统计majority参数统计问题
  • vue2+wangEditor5富文本编辑器(图片视频自定义上传七牛云/服务器)
  • shell脚本练习--安全封堵脚本,使用firewalld实现
  • 双端冒泡排序
  • 如何在Visual Studio Code中用Mocha对TypeScript进行测试
  • GO中Json的解析
  • chatgpt 提示词-关于数据科学的 75个词语
  • (自控原理)控制系统的数学模型
  • Webpack5 cacheGroups
  • 前端面试的游览器部分(5)每篇10题
  • 数据挖掘七种常用的方法汇总
  • 自然语言处理学习笔记(二)————语料库与开源工具
  • Rust dyn - 动态分发 trait 对象
  • uniapp 中过滤获得数组中某个对象里id:1的数据
  • Django系列之Channels
  • HTTP——五、与HTTP协作的Web服务器
  • pyspark笔记 Timestamp 类型的比较
  • SpringBoot 集成 Redis