- memory[meta header]
- std[meta namespace]
- unique_ptr[meta class]
- function[meta id-type]
- cpp11[meta cpp]
void reset(pointer p = pointer()) noexcept; // (1) C++11
constexpr void reset(pointer p = pointer()) noexcept; // (1) C++23
// 配列版のみ
void reset(nullptr_t p) noexcept; // (2) C++11
void reset(nullptr_t = nullptr) noexcept; // (2) C++17
constexpr void reset(nullptr_t = nullptr) noexcept; // (2) C++23
template <class U> void reset(U) = delete; // (3) C++11
template <class U> void reset(U p) noexcept; // (3) C++17
template <class U> constexpr void reset(U p) noexcept; // (3) C++23
リソースを解放し、新たなリソースの所有権を設定する。
-
(1) : 保持しているポインタ変数に
p
を代入する。デフォルト引数を使用する場合、この関数を呼び出したあと*this
はリソースを保持していない状態になる。 代入前に保持していたポインタ変数をold_p
とし、それがnullptr
でなければ、get_deleter()
(old_p)
によって、保持していたポインタを解放する。 -
(2) :
reset(pointer())
と等価の効果を持つ。
-
(3) :
- C++14まで : 他のポインタ型から
pointer
型への変換を禁止する。 - C++17 : (1)と等価、ただし以下のどちらかの場合にのみオーバーロード解決に参加する。
U
はメンバ型pointer
と同じ型pointer
はelement_type*
と同じ型かつU
は何らかのポインタ型V*
であり、V(*)[]
はelement_type(*)[]
に変換可能である
- C++14まで : 他のポインタ型から
なし
#include <iostream>
#include <memory>
int main()
{
std::unique_ptr<int> p(new int(3));
// リソースを解放
p.reset();
if (!p) {
std::cout << "p doesn't have resource" << std::endl;
}
// リソースを再設定
p.reset(new int(2));
std::cout << *p << std::endl;
}
- reset[color ff0000]
p doesn't have resource
2
- C++11
- GCC: 4.4.7 [mark verified]
- Clang: 3.0 [mark verified]
- ICC: ?
- Visual C++: 2010 [mark verified], 2012 [mark verified], 2013 [mark verified]
- 2012までは、delete宣言に対応していないため、代わりにprivateで宣言のみ行う手法で代用されている。