- memory[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp20[meta cpp]
namespace std {
template<class T>
shared_ptr<T> make_shared_for_overwrite(); // (1)
template<class T>
shared_ptr<T> make_shared_for_overwrite(size_t N); // (2)
}
- shared_ptr[link shared_ptr.md]
T
型のオブジェクト、またはその配列へのshared_ptr
を構築し、返却する。
型T
のオブジェクトにメモリを割り当てる(T
がU[]
の場合はU[N]
。N
はそれぞれのオーバーロードで指定された引数から決定される)。
すべてのオーバーロードにおいて、確保された領域のオブジェクトはデフォルト構築される。
例外がスローされた場合、関数は効果がない。
非配列型U
の(サブ)オブジェクトがこの関数によって初期化されるときは、式::new(pv) U
によって初期化される。ここで、pv
は型 void *
を持ち、型U
のオブジェクトを保持するための適切なストレージを指す。
配列要素は、アドレスの昇順で初期化される。
戻り値によって管理されるオブジェクトのlifetime
が終了するか、配列要素の初期化が例外をスローすると、初期化された要素は元の構造の逆の順序で破棄される。
- (1) : このオーバーロードが選択されるとき、
T
は、不明な境界の配列ではない。T
型のオブジェクトへのshared_ptr
を返す。 - (2) : このオーバーロードが選択されるとき、
T
は、不明な境界の配列である。型U[N]
のオブジェクトへのshared_ptr
を返す。ここで、U
はremove_extent_t<T>
である。
新しく構築されたオブジェクトのアドレスを格納および所有するshared_ptr
インスタンス。
r.get() != 0 && r.use_count() == 1
, ここで、r
は戻り値である。
bad_alloc
、またはallocate
またはオブジェクトの初期化からスローされた例外。
メモリの確保にユーザー定義のアロケータを使用したい場合には、 allocate_shared_for_overwrite()
を使用する。
デフォルト構築においては、トリビアルにデフォルト構築可能な型のオブジェクトは未初期化状態となるため、値を読みだす前に明示的に初期化(overwrite)する必要がある。初期化後の状態が不定になってほしくない場合はこの関数ではなくmake_shared()
を使用すべき。
#include <memory>
#include <iostream>
int main() {
std::shared_ptr<int> sp = std::make_shared_for_overwrite<int>();
if (sp) {
*sp = 0; // 必ず初期化する
std::cout << *sp << std::endl;
}
}
- std::make_shared_for_overwrite[color ff0000]
0
- C++20
- Clang: 10.0.0 現在未対応 [mark verified]
- GCC: 10.0.0 現在未対応 [mark verified]
- Visual C++: ??