std::shared_ptr<T>::owner_equal
来自 cppreference.com
< cpp | memory | shared ptr
template< class Y > bool owner_equal( const std::shared_ptr<Y>& other ) const noexcept; |
(1) | (自 C++26 起) |
template< class Y > bool owner_equal( const std::weak_ptr<Y>& other ) const noexcept; |
(2) | (自 C++26 起) |
检查此 shared_ptr
和 other 是否共享所有权或两者都为空。比较方式是,两个智能指针仅当它们都为空,或者当它们都拥有同一个对象时才被认为是等效的,即使通过 get() 获得的指针值不同(例如,因为它们指向同一个对象内的不同子对象)。
成员函数 owner_equal
是一个等价关系,因此 !owner_before(other) && !other.owner_before(*this) 为 true 当且仅当 owner_equal(other) 为 true。
此排序用于使共享指针和弱指针能够用作无序关联容器中的键,通常通过 std::owner_equal。
内容 |
[编辑] 参数
other | - | 要比较的 std::shared_ptr 或 std::weak_ptr |
[编辑] 返回值
如果 *this 和 other 共享所有权或两者都为空,则为 true。否则,返回 false。
[编辑] 备注
特性测试 宏 | 值 | 标准库 | 特性 |
---|---|---|---|
__cpp_lib_smart_ptr_owner_equality |
202306L | (C++26) | 启用将 std::shared_ptr 用作 无序关联容器 中的键值。 |
[编辑] 示例
本节内容尚未完善 原因: 示例 |
[编辑] 参见
(C++26) |
提供基于所有权的混合类型共享指针和弱指针的相等比较。 (类) |