提高共享内存有效性
Boost Shared Memory validity
我正在使用Boost共享内存在进程之间共享向量。
在客户端,我怎么能,一旦我尝试打开共享内存并读取它的向量,意识到如果内存无效,或者不是我要找的。
如果内存段不存在,Open_Only
是否会失败,如果存在,我如何捕获此失败?
同样,如果没有对共享内存段的引用,它应该被删除。然而,在我的情况下,即使客户机和服务器都关闭,并且没有其他东西正在访问共享内存,段仍然在程序数据中的Boost进程间文件夹中,并带有一些数据。因此,下次客户端启动时,它打开段没有问题,因此认为它正在访问正确的数据,而实际上没有数据要共享。
请建议。谢谢你。
从底层shm api的经验来看——而不是作为Boost专家…
要确定有效性,一种技术是确定当前进程是否是创建共享内存的进程(第一次)。您可以通过在创建(fstat)后获取大小并查看大小是否为零来实现这一点。如果它是零,这个过程正在生成它。一旦知道了这一点,就可以初始化它。此外,当您调用truncate()来设置这里的大小时,将为所有其他进程设置该大小。
为了确保删除,可以调用shm_unlink()从系统中删除共享内存文件。我相信在Boost中有一个remove() api可以做到这一点。
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 如何在最大限度地提高大小有效性的同时,将3态的位运算符实现为任何大小的内存
- 提高共享内存有效性