提升进程间共享内存open_or_create每次都会引发异常
Boost inter process shared memory open_or_create throws exception every time
我正在写入实时数据以增加共享内存。最初,每次我想访问shm时,我都会使用它:
boost::interprocess::managed_shared_memory segment(boost::interprocess::open_or_create, "MySharedMemory",20000000);
在调试模式下,我发现此调用总是抛出此异常:
First-chance exception at 0x00007FFA30BB95FC in testerud.exe: Microsoft C++ exception: boost::interprocess::interprocess_exception at memory location 0x000000000550E1C0.
但是我能够打开并将我的数据推送到共享内存。我找到了这个问题的转折点。我创建了另一个函数,只是为了在流程开始时open_or create
,然后每次都使用open_only
编写。没有例外。
我很好奇这背后的原因。
来自提升文档:
托管内存段还提供了循环访问构造的命名对象和唯一对象以进行调试的可能性。注意:此迭代不是线程安全的,因此用户应确保没有其他线程在段中操作命名或唯一索引(创建、擦除、保留...(。可以同时执行不涉及索引的其他操作(例如,原始内存分配/解除分配(。
相关文章:
- 处理多个异常集合的C++方法
- 我在c++代码中生成了一个运行时#3异常
- 孤立代码块在结构中引发异常
- C++中的赋值发生,尽管右侧出现异常
- 从构造函数抛出异常时如何克服内存泄漏
- 异常属于C++中的线程还是进程
- 当类定义不可见时捕获异常
- 引发异常:读取访问冲突**dynamicArray**为0x1118235.发生
- 为什么异常不退出程序?
- 为什么我应该在异常处理中使用std::cerr而不是std::cout
- 如何修复链表类实现的未处理异常0xDDDDDDDD
- 关于:C++中异常对象的范围:为什么我没有得到副本?
- 是什么导致了Unity 3D中的"错误线程异常"?
- 如何将strftime中的格式错误作为异常捕获
- 创建具有 new in 函数和"this is nullptr"异常的对象
- 尝试使用智能指针时引发异常
- 函数如何通知用户它基于函数原型抛出异常?
- 是否值得降低我的代码的可读性,以便在出现内存不足错误时提供异常安全性?
- Firebase C++VS2018 SDL2-在Firebase::app::create(..)上执行异常处理
- B2Shape等于0xCDCDCDCD,并在Create灯具时抛出异常