命名空间
变体
操作

std::unique_ptr<T,Deleter>::reset

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



 
 
主模板的成员,unique_ptr<T>
void reset( pointer ptr = pointer() ) noexcept;
(1) (C++23 以来为 constexpr)
特化 unique_ptr<T[]> 的成员
template< class U >
void reset( U ptr ) noexcept;
(2) (C++23 以来为 constexpr)
void reset( std::nullptr_t = nullptr ) noexcept;
(3) (C++23 以来为 constexpr)

替换托管对象。

1,2) 等同于 auto old_ptr = get();
/* 将“ptr”分配给存储的指针 */
if (old_ptr)
    get_deleter()(old_ptr);
.
如果 get_deleter()(old_ptr) 抛出异常,行为未定义。
2) 仅当 Upointer 类型相同,或满足以下所有条件时,此重载才参与重载解析
  • pointerelement_type* 类型相同。
  • U 是一种指针类型 V*,使得 V(*)[] 可转换为 element_type(*)[]
3) 等同于 reset(pointer()).

内容

[编辑] 参数

ptr - 指向要管理的新对象的指针

[编辑] 备注

要替换托管对象并同时提供新的删除器,可以使用移动赋值运算符。

对自重置的测试,即 ptr 是否指向由 *this 管理的对象,不会执行,除非作为编译器扩展或调试断言提供。请注意,诸如 p.reset(p.release()) 的代码不涉及自重置,只有诸如 p.reset(p.get()) 的代码才涉及。

[编辑] 示例

#include <iostream>
#include <memory>
 
struct Foo // object to manage
{
    Foo() { std::cout << "Foo...\n"; }
    ~Foo() { std::cout << "~Foo...\n"; }
};
 
struct D // deleter
{
    void operator() (Foo* p)
    {
        std::cout << "Calling delete for Foo object... \n";
        delete p;
    }
};
 
int main()
{
    std::cout << "Creating new Foo...\n";
    std::unique_ptr<Foo, D> up(new Foo(), D()); // up owns the Foo pointer (deleter D)
 
    std::cout << "Replace owned Foo with a new Foo...\n";
    up.reset(new Foo());  // calls deleter for the old one
 
    std::cout << "Release and delete the owned Foo...\n";
    up.reset(nullptr);      
}

输出

Creating new Foo...
Foo...
Replace owned Foo with a new Foo...
Foo...
Calling delete for Foo object...
~Foo...
Release and delete the owned Foo...
Calling delete for Foo object...
~Foo...

[编辑] 缺陷报告

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

DR 应用于 已发布的行为 正确行为
LWG 2118 C++11 unique_ptr<T[]>::reset 拒绝限定转换 接受
LWG 2169 C++11 重载 unique_ptr<T[]>::reset(pointer) 存在 删除了重载

[编辑] 参见

返回指向托管对象的指针并释放所有权
(公有成员函数) [编辑]