6

请考虑以下结构:

struct ThingThatWillGoInSharedMemory {
    boost::optional<int> opt_value;
};

我正在使用 boost::interprocess 来创建共享内存区域。我对 boost::optional 的理解是它是一个有区别的联合而不是一个可为空的指针。作为一个反例,使用堆的 std::map 和 std::vector 需要显式分配器才能在进程间内存中使用它们,但是 boost::optional,我相当确定不使用堆并且等效于写作:

struct ThingThatWillGoInSharedMemory {
    bool value_initialised;
    int value;
}

所以它可以开箱即用。如果有人证实这一点,我会很高兴 - 我没有看到 boost::optional 文档中明确提到了进程间案例,只是暗示。

4

1 回答 1

2

你是对的。boost::optional 包装值,而不是使用指针间接。这意味着普通的旧数据对象(例如 int)可以存在于共享内存区域中。一般来说,利用堆的对象不能以这种方式使用。

来自 boost::optional 文档:

必须牢记可选和指针之间的区别,特别是因为关系运算符的语义不同:因为可选是一个值包装器......

boost::optional 包装值,而不是使用指针和间接。您的 boost::optional 内存布局的基本模型或多或少是正确的。实际实现使用一个联合包装通用对齐字节缓冲区,以避免必须初始化 T 对象。该库使用 & (address-of) 运算符来获取进程地址空间中字节缓冲区的本地映射地址。然后将此本地内存地址强制转换为 T 类型的指针或引用。

源代码可以在<boost/optional/optional.hpp>找到

于 2013-12-29T23:43:28.040 回答