我在一个运行在windows上的C++程序中有一个结构,我想使用ctype在Python中通过共享内存访问它。例如:
#define MAX_ENTITIES 30
struct State
{
double x;
double y;
double z;
};
struct Stat
{
unsigned int numAvailable;
unsigned int numUsed;
};
struct TransferData
{
double exLg;
float other;
unsigned int more;
int more2;
unsigned char next;
bool statusReady;
Stat status;
State entities[MAX_ENTITIES];
};作为:
import ctypes
MAX_ENTITIES = 30
class State(ctypes.Structure):
_fields_ = [
('x', ctypes.c_double),
('y', ctypes.c_double),
('z', ctypes.c_double)
]
class Stat(ctypes.Structure):
_fields_ = [
('numAvailable', ctypes.c_uint),
('numUsed', ctypes.c_uint)
]
class TransferData(ctypes.Structure):
_fields_ = [
('exLg', ctypes.c_double),
('other', ctypes.c_float),
('more', ctypes.c_uint),
('more2', ctypes.c_int),
('next', ctypes.c_ubyte),
('statusReady', ctypes.c_bool),
('status', Stat),
('entities', State * MAX_ENTITIES)
]我希望:
shmem = mmap.mmap(-1, ctypes.sizeof(TransferData.TransferData),
"TransferDataSHMEM")
data = TransferData.from_buffer(shmem)将使数据成为C++端所表示内容的共享内存镜像,但它都是零。
发布于 2015-06-24 21:30:37
我发现的诀窍实际上是在boost::interprocess这一端。而不是创建一个普通的共享内存区域:
shared_memory_object shmem(open_or_create, "CppTransferDataSHMEM", read_write);
shmem.truncate(sizeof(TransferData));
mapped_region region(shmem, read_write);
TransferData* data = reinterpret_cast<TransferData*>(region.get_address());windows上的Python (带有-1文件描述符)要求将内存映射到页面文件。Boost实现了这一点,但使用了替代shared_memory_object而不是默认的windows_shared_memory。
工作代码如下:
windows_shared_memory shmem(create_only, "TransferDataSHMEM",
read_write, sizeof(TransferData));
mapped_region region(shmem, read_write);
std::memset(region.get_address(), 0, sizeof(TransferData));
TransferData* data = reinterpret_cast<TransferData*>(region.get_address());我已经用我的complete example solution创建了一个github存储库。
https://stackoverflow.com/questions/31028012
复制相似问题