提升::none_t实施的基本原理是什么
What is the rationale for boost::none_t implementation?
Boost.Optional 使用虚拟类型来允许构造boost::optional<T>
的未初始化实例。这种类型称为 none_t
,为了方便起见,已经在标头中定义了实例none
,允许我们编写如下代码:
boost::optional<int> uninitialized(boost::none);
查看none_t
的定义,我注意到它实际上是一个 typedef,对应于指向某个虚拟结构的成员的指针:
namespace boost {
namespace detail { struct none_helper{}; }
typedef int detail::none_helper::*none_t ;
none_t const none = (static_cast<none_t>(0)) ;
} // namespace boost
与像这样的简单空结构相比,使用如此复杂的 typedef 有什么优势?
namespace boost {
struct none_t {};
none_t const none;
} // namespace boost
啊,我从来没有想过要深入挖掘。
常规struct
的一个(或多或少明显)优点是现在none
计算值为布尔上下文中的false
。
与另一个"计算为 false"相比,一个优点是防止指向成员的指针有害地提升为整型。
所以,我想它提供了一种安全简洁的方式来拥有一个评估为 false
的对象。
编辑:人们应该在这里认识到(哼哼...)安全布尔习语的结构。
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么