命名空间
变体
操作

std::shared_ptr<T>::use_count

来自 cppreference.com
< cpp‎ | memory‎ | shared ptr
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库功能测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三方比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
动态内存管理
未初始化内存算法
受约束的未初始化内存算法
分配器
垃圾回收支持
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)
(C++11)(直到 C++23)



 
 
long use_count() const noexcept;

返回管理当前对象的 shared_ptr 实例数(包括 *this)。如果不存在被管理的对象,则返回 0

在多线程环境中,use_count 原子地检索实例数(典型实现使用 memory_order_relaxed 加载)。

内容

[编辑] 参数

(无)

[编辑] 返回值

管理当前对象的 std::shared_ptr 实例数,如果不存在被管理的对象,则返回 0

[编辑] 注释

常见用例包括

  • 0 进行比较。如果 use_count 返回零,则共享指针为空,不管理任何对象(无论其存储的指针是否为 nullptr)。
  • 1 进行比较。如果 use_count 返回 1,则没有其他所有者。 此用例提供了 已弃用(自 C++17 起) 成员函数 unique()(直到 C++20)

在多线程环境中

use_count 返回的值应被视为近似值,因为在原子检索和有意义地使用该值之间,其他线程中的共享所有者数量可能会发生变化。当 use_count 返回 1 时,它并不意味着该对象是安全的,因为以前共享所有者的访问可能尚未完成,并且新的共享所有者可能同时被引入,例如通过 std::weak_ptr::lock。只有当 use_count 返回 0 时,计数才是准确的。

[编辑] 示例

#include <iostream>
#include <memory>
 
void fun(std::shared_ptr<int> sp)
{
    std::cout << "in fun(): sp.use_count() == " << sp.use_count()
              << " (object @ " << sp << ")\n";
}
 
int main()
{
    auto sp1 = std::make_shared<int>(5);
    std::cout << "in main(): sp1.use_count() == " << sp1.use_count()
              << " (object @ " << sp1 << ")\n";
 
    fun(sp1);
}

可能的输出

in main(): sp1.use_count() == 1 (object @ 0x20eec30)
in fun(): sp.use_count() == 2 (object @ 0x20eec30)

[编辑] 参见

(直到 C++20)
检查托管对象是否仅由当前 shared_ptr 对象管理
(公共成员函数) [编辑]