促进进程间 Win32,x64
Boost interprocess Win32, x64
我想使用 boost 进程间在不同平台之间进行通信。
我在 windows 7.
上使用 vc12 和 boost 1.58
我下面的代码是一个非常简单的示例,应该可以。但它不适用于不同平台之间的通信...
如果我在 x64 中创建 msm 并在 win32 中打开,进程会卡在 try_based_lock 函数 try_based_lock in boost/int/sync/detail/common_algorithms.hpp
中
相反:win32 创建,x64 打开:进程在 segment_manager_helper.hpp 中的 name_length 处崩溃,同时试图在索引中查找名称(priv_generic_find 在 segment_manager).
问题出现在msm.find("Data")
#include <iostream>
#include <boost/interprocess/managed_shared_memory.hpp>
int main() {
namespace bip = boost::interprocess;
// open in WIN32, create in x64
#ifndef _WIN64
bip::managed_shared_memory msm(bip::open_only, "TestIPC");
#else
bip::shared_memory_object::remove("TestIPC");
bip::managed_shared_memory msm(bip::create_only, "TestIPC", 4096);
msm.construct<uint32_t>("Data")[1](10);
#endif
// Get Data and print it
auto data = msm.find<uint32_t>("Data");
if (data.second == 1) {
std::cout << *data.first << std::endl;
}
std::cin.ignore();
return 0;
}
有人有这方面的经验吗?
boost::interprocess
使用托管共享内存 类 的 32 位和 64 位模式之间的通信似乎不受支持或存在错误。虽然在较低级别上工作正常。这是示例代码:
#include <boost/interprocess/shared_memory_object.hpp>
#include <boost/interprocess/mapped_region.hpp>
#include <iostream>
int main(int argc, char *argv[])
{
using namespace boost::interprocess;
#ifndef _WIN64
shared_memory_object shm(open_only, "MySharedMemory", read_write);
mapped_region region(shm, read_only);
uint8_t *ptr = static_cast<uint8_t*>(region.get_address());
std::cout << int32_t(*ptr) << std::endl;
#else
shared_memory_object shm(create_only, "MySharedMemory", read_write);
shm.truncate(4096);
mapped_region region(shm, read_write);
uint8_t *ptr = static_cast<uint8_t*>(region.get_address());
*ptr = 5;
#endif
return 0;
}
我想使用 boost 进程间在不同平台之间进行通信。
我在 windows 7.
上使用 vc12 和 boost 1.58我下面的代码是一个非常简单的示例,应该可以。但它不适用于不同平台之间的通信...
如果我在 x64 中创建 msm 并在 win32 中打开,进程会卡在 try_based_lock 函数 try_based_lock in boost/int/sync/detail/common_algorithms.hpp
中相反:win32 创建,x64 打开:进程在 segment_manager_helper.hpp 中的 name_length 处崩溃,同时试图在索引中查找名称(priv_generic_find 在 segment_manager).
问题出现在msm.find("Data")
#include <iostream>
#include <boost/interprocess/managed_shared_memory.hpp>
int main() {
namespace bip = boost::interprocess;
// open in WIN32, create in x64
#ifndef _WIN64
bip::managed_shared_memory msm(bip::open_only, "TestIPC");
#else
bip::shared_memory_object::remove("TestIPC");
bip::managed_shared_memory msm(bip::create_only, "TestIPC", 4096);
msm.construct<uint32_t>("Data")[1](10);
#endif
// Get Data and print it
auto data = msm.find<uint32_t>("Data");
if (data.second == 1) {
std::cout << *data.first << std::endl;
}
std::cin.ignore();
return 0;
}
有人有这方面的经验吗?
boost::interprocess
使用托管共享内存 类 的 32 位和 64 位模式之间的通信似乎不受支持或存在错误。虽然在较低级别上工作正常。这是示例代码:
#include <boost/interprocess/shared_memory_object.hpp>
#include <boost/interprocess/mapped_region.hpp>
#include <iostream>
int main(int argc, char *argv[])
{
using namespace boost::interprocess;
#ifndef _WIN64
shared_memory_object shm(open_only, "MySharedMemory", read_write);
mapped_region region(shm, read_only);
uint8_t *ptr = static_cast<uint8_t*>(region.get_address());
std::cout << int32_t(*ptr) << std::endl;
#else
shared_memory_object shm(create_only, "MySharedMemory", read_write);
shm.truncate(4096);
mapped_region region(shm, read_write);
uint8_t *ptr = static_cast<uint8_t*>(region.get_address());
*ptr = 5;
#endif
return 0;
}