如何在python和C / C ++中使用共享内存

问题描述 投票:4回答:1

我试图修改一个python程序,以便能够使用共享内存与C ++程序进行通信。 python程序的主要职责是从位于共享内存中的输入队列中读取一些视频帧,对视频帧执行某些操作并将其写回共享内存中的输出队列。

我相信我需要做的事情很少,如果有人能够对它有所了解,那就太棒了:

  1. 共享内存:在C / C ++中,您可以使用shmgetshmat等函数来获取指向共享内存的指针。在python中处理这个的等效方法是什么,所以python和C ++程序都可以使用相同的共享内存?
  2. 同步:因为这涉及多处理,我们需要在C ++和python程序中为共享内存提供某种锁定机制。我怎么能在python中这样做?

非常感谢!

python c++ synchronization multiprocessing
1个回答
1
投票

也许shmgetshmat不一定是你使用的最合适的接口。在我工作的项目中,我们使用内存映射文件通过C和Python API提供对守护程序的访问,这为我们提供了一种非常快速的访问数据的方法

操作顺序有点像这样:

  • 客户端使用door_call()告诉守护进程创建共享内存区域
  • 守护进程安全地创建一个临时文件
  • 守护进程open()s然后mmap()s那个文件
  • 守护进程通过door_return()将文件描述符传递回客户端
  • 客户端qazxswpo是文件描述符,并将具有该fd的结构中的连续放置的变量关联起来
  • 客户端需要对这些变量执行任何操作 - 何时需要执行此操作。
  • 守护进程从共享区域读取并执行自己的更新(在我们的示例中,将该共享区域中的值写入日志文件)。

我们的客户使用库来处理上面的前5个步骤;该库附带了使用ctypes的Python包装器,以准确显示所需的功能和数据类型。

对于你的问题空间,如果它只是写入你的输出队列的python应用程序,那么你可以跟踪python应用程序中已处理的帧。如果你的python和c ++应用程序都写入输出队列,那么这会增加你的难度,也许重构整个应用程序架构将是一个很好的投资。

© www.soinside.com 2019 - 2024. All rights reserved.