Windows和Linux下使用共享内存在C++和Python之间共享DataFrame

参考资料

  • windows api: https://docs.microsoft.com/en-us/windows/win32/api/
  • 《Linux-UNIX系统编程手册》
  • Python Doc: https://docs.python.org/3/library/mmap.html
  • Linux manual: https://man7.org/linux/man-pages/man2/mmap.2.html

实现(windows)

主要功能

用C++创建共享内存,用Python进行读取,用csv格式传递DataFrame

Q&A

Q:为什么使用csv格式?
A:如果使用binary格式,需要用python的struct.unpack解析二进制数据,相当于在Python环境下执行数据解析,这会非常慢,数据量大的话,可能会比写文件还慢。使用csv,C++写入一个字符流,Python中调用pd.read_csv,也是在C++代码中解析csv,因此比较快。
Q:为什么不将Python嵌入到C++中,用函数参数传递来传递DataFrame
A:这种方式传递参数,也会非常非常慢

实现步骤

  1. 调用CreateFile创建文件
  2. 调用CreateFileMapping将创建的内存文件映射到本进程的内存空间
  3. 调用MapViewOfFile获得共享内存在本进程内存空间内的地址
  4. 写数据

2022-08-25补充-用numpy共享raw binary data

// in C++ code, share an int array as example
// create shared memory first, lp_base is the shared memory ptr
int32_t stocks[] = { 1,2, 300001, 688001 };
int len = sizeof(stocks);
char* ptr = (char*)lp_base;
memcpy(ptr,
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值