命名空间
变体
操作

std::weak_ptr<T>::expired

来自 cppreference.com
< cpp‎ | memory‎ | weak 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)



 
 
bool expired() const noexcept;
(自 C++11 起)

等效于 use_count() == 0。托管对象的析构函数可能尚未被调用,但此对象的析构即将发生(或可能已经发生)。

内容

[编辑] 参数

(无)

[编辑] 返回值

如果托管对象已被删除,则为 true,否则为 false

[编辑] 备注

如果托管对象在多个线程之间共享,则只有在 expired() 返回 true 时才有意义。

[编辑] 示例

演示如何使用 expired 检查指针的有效性。

#include <iostream>
#include <memory>
 
std::weak_ptr<int> gw;
 
void f()
{
    if (!gw.expired())
	std::cout << "gw is valid\n";
    else
        std::cout << "gw is expired\n";
}
 
int main()
{
    {
        auto sp = std::make_shared<int>(42);
	gw = sp;
 
	f();
    }
 
    f();
}

输出

gw is valid
gw is expired

[编辑] 另请参阅

创建一个管理引用对象的 shared_ptr
(公共成员函数) [编辑]
返回管理该对象的 shared_ptr 对象的数量
(公共成员函数) [编辑]