命名空间
变体
操作

std::inout_ptr_t<Smart,Pointer,Args...>::~inout_ptr_t

来自 cppreference.com
< cpp‎ | memory‎ | inout ptr t
 
 
实用程序库
语言支持
类型支持 (基本类型,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)



 
 
~inout_ptr_t();
(自 C++23 起)

通过修改后的 Pointer 对象的值(或如果已调用 operator void**(),则为 void* 对象)以及捕获的参数来重置已适配的 Smart 对象。如果构造函数没有调用 release(),则可以在已适配的 Smart 对象上调用 release()

  • s 表示已适配的 Smart 对象,
  • args... 表示捕获的参数,
  • p 表示存储的 Pointer 的值,或如果已调用 operator void**,则表示 static_cast<Pointer>(*operator void**())
  • SP
    • Smart::pointer,如果它有效且表示一个类型,否则,
    • Smart::element_type*,如果 Smart::element_type 有效且表示一个类型,否则,
    • std::pointer_traits<Smart>::element_type*,如果 std::pointer_traits<Smart>::element_type 有效且表示一个类型,否则,
    • Pointer,
  • /*do-release*/ 表示 s.release(),如果 构造函数 没有调用 release(),否则为空。

如果 Smart 是一个指针类型,则析构函数执行

s = static_cast<Smart>(p);,并且如果 sizeof...(Args) > 0,则程序格式错误。

否则,如果 s.reset(static_cast<SP>(p), std::forward<Args>(args)...) 格式正确,则析构函数执行

/*do-release*/; if (p) { s.reset(static_cast<SP>(p), std::forward<Args>(args)...); };

否则,如果 std::is_constructible_v<Smart, SP, Args...>true,则析构函数执行

/*do-release*/; if (p) { s = Smart(static_cast<SP>(p), std::forward<Args>(args)...); };

否则,程序格式错误。

[编辑] 说明

实现可能在构造期间为 Smart 所需的数据结构(例如控制块)分配存储空间,以便将非抛出工作留给析构函数。

按值捕获的参数在重置后被销毁。

[编辑] 缺陷报告

以下改变行为的缺陷报告被追溯应用于之前发布的 C++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 3897 C++23 析构函数没有将原始指针更新为 null 值 它确实会更新