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

跨平台进程池背后的思想

        背景是基于业务需求,需要实现一个跨平台的项目。项目中由于有部分功能存在大量计算,所以打算单独分配一个进程去进行计算。
        进程池的实现与线程池的实现逻辑上如出一辙。但是实现上进程池的实现会比线程池实现复杂的多,主要比较复杂的点的就在于并发安全的任务队列。考虑到跨平台的要求,我使用的是boost库中用于进程管理的boost::process,具体使用请参阅相相关文档。
        目前是进程管理没有问题,下面就是需要考虑进程间的通信和并发控制的问题。进程间并发控制其实是比较好解决的,使用boost库中进程相关的有名锁、有名条件变量等即可,其都是基于全局共享内存,当然关于全局共享内存是如何在进程之间互相识别的这个问题,其实我们也能从其前缀得到一些启发:“有名”,那固然是你创建这些控制条件变量的时候取一个名字,很明显这个名字与全局共享内存块形成了一个映射,并且这个映射也是全局的,以便所有进程都能访问该变量。这一点你在程序中创建对应的对象并且使用的时候你就能深有体会。
        下面就是“最赖皮”的部分,任务队列的实现。我们都知道,关于池类技术都离不开一个生产者-消费者模型,可能是一对一也可能是多对多,横竖不管怎样,就是生产者将任务生产到一个队列,消费者基于这个队列进行消费。如果是在单进程多线程模型中这种队列十分好设计,因为维护队列的动态内存在我们程序中可控制的,可以依据任务的大小和数量进行分配。但是在多进程间,全局的共享内存只能进行固定的分配,没有

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

相关文章:

  • 前端性能优化之加载篇
  • 数据结构(栈)
  • Aspose.PDF功能演示:使用 JavaScript 从 PDF 中提取文本
  • 计算机系统简介
  • 学习文档10/18
  • Redis入门到精通(二):入门Redis看这一篇就够了
  • 荒岛逃生游戏
  • 玫瑰花HTML源码
  • 【wpf】07 后端验证及令牌码获取步骤
  • 学习中,师傅b站泷羽sec——xss挖掘过程
  • 什么是双因素身份验证?双因素身份验证的凭据类型有哪些?
  • 【MR开发】在Pico设备上接入MRTK3(一)——在Unity工程中导入MRTK3依赖
  • 利用移动式三维扫描技术创建考古文物的彩色纹理网格【上海沪敖3D】
  • Spring AI Java程序员的AI之Spring AI(四)
  • 精选20个爆火的Python实战项目(含源码),直接拿走不谢!
  • Rocky Linux 9安装Asterisk 20和freepbx 17脚本——筑梦之路
  • PSPICE FOR TI笔记记录1
  • Java集合剖析4】LinkedList
  • 基于MATLAB/octave的容积卡尔曼滤波(CKF)【带逐行注释】
  • Python编程探索:从基础语法到循环结构实践(下)
  • 简介openwrt系统下/etc/config/network文件生成过程
  • javaWeb项目-Springboot+vue-XX图书馆管理系统功能介绍
  • 华为ENSP用户权限深度解析:构建安全高效的网络管理
  • NFC之NDEF
  • 学习第三十六行
  • 停车场问题
  • 海康相 机
  • 用map实现el-table全选
  • 【开源免费】基于SpringBoot+Vue.JS社区团购系统(JAVA毕业设计)
  • Java进阶之路:构造方法