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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在python和C / C ++中使用共享内存相关的知识,希望对你有一定的参考价值。

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

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

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

非常感谢!

答案

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

操作顺序有点像这样:

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

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

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

以上是关于如何在python和C / C ++中使用共享内存的主要内容,如果未能解决你的问题,请参考以下文章

如何在 c 中使用 posix 命名信号量和 Linux 上两个进程之间的共享内存?

在 C/C++ 共享内存中等待和通知

如何使用共享内存在 cpp 和 python 之间共享 cv::Mat 以进行处理

如何在 C 中分析 openMPI 程序的内存使用情况和性能

在 C 和 C++ 中如何分配和释放 *array* 内存?

如何正确销毁 C 中多个进程使用的共享未命名信号量?