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 原子地获得实例的数量(典型实现使用 std::memory_order_release 加载)。

参数

(无)

返回值

管理当前对象的 std::shared_ptr 实例的数量,或若无被管理对象则为 0

注解

常用用法包括

  • 0 比较。若 use_count 返回 0,则智能指针为 且不管理对象(无论被存储指针是否为空)。多线程环境中,这不隐含被管理对象的析构函数已完成。
  • 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 的对象管理
(公开成员函数)