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

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

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

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

非常感谢!

解决方法:

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

操作顺序有点像这样:

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

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

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

上一篇:java – 执行查询后修改MongoDB结果集


下一篇:PHP / MySQL概念数据库’同步’问题