名前空間
変種
操作

std::raw_storage_iterator

From cppreference.com
< cpp‎ | memory
 
 
メモリ管理ライブラリ
(説明用*)
未初期化メモリのアルゴリズム
(C++17)
(C++17)
(C++17)
制約付き未初期化
メモリアルゴリズム
Cライブラリ

アロケータ
メモリリソース
ガベージコレクションのサポート
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
未初期化ストレージ
raw_storage_iterator
(C++20まで*)
(C++20まで*)
明示的な生存期間管理
 
 
ヘッダ <memory> で定義
template< class OutputIt, class T >

class raw_storage_iterator

    : public std::iterator<std::output_iterator_tag, void, void, void, void>;
(C++17まで)
template< class OutputIt, class T >
class raw_storage_iterator;
(C++17以降)
(C++17で非推奨)
(C++20で削除)

出力イテレータ std::raw_storage_iterator は、標準アルゴリズムが初期化されていないメモリに結果を保存することを可能にします。アルゴリズムが型 T のオブジェクトをデリファレンスされたイテレータに書き込むたびに、そのオブジェクトはイテレータが指す初期化されていないストレージ内の場所にコピー構築されます。テンプレートパラメータ OutputIt は、LegacyOutputIterator の要件を満たし、operator* がオブジェクトを返すように定義されており、そのオブジェクトに対して operator& が型 T* のオブジェクトを返す任意の型です。通常、型 T*OutputIt として使用されます。

目次

[編集] 型要件

-
OutputItLegacyOutputIterator の要件を満たさなければなりません。

[編集] メンバ関数

新しい raw_storage_iterator を作成する
(public メンバ関数) [編集]
バッファ内の指された場所にオブジェクトを構築する
(public メンバ関数) [編集]
イテレータをデリファレンスする
(public メンバ関数) [編集]
イテレータを進める
(public メンバ関数) [編集]
(C++17以降)
ラップされたイテレータへのアクセスを提供する
(public メンバ関数) [編集]

[編集] メンバ型

メンバ型 定義
iterator_category std::output_iterator_tag
value_type void
difference_type

void

(C++20まで)

std::ptrdiff_t

(C++20以降)
pointer void
reference void

メンバ型 iterator_category, value_type, difference_type, pointer, reference は、std::iterator<std::output_iterator_tag, void, void, void, void> から継承することで取得する必要があります。

(C++17まで)

[編集] 注意

std::raw_storage_iterator は、主に例外安全でない振る舞いのため非推奨となりました。std::uninitialized_copy とは異なり、std::copy のような操作中に例外を安全に処理せず、構築されたオブジェクトの数や例外発生時の適切な破棄を追跡しないため、リソースリークにつながる可能性があります。

[編集]

#include <algorithm>
#include <iostream>
#include <memory>
#include <string>
 
int main()
{
    const std::string s[] = {"This", "is", "a", "test", "."};
    std::string* p = std::allocator<std::string>().allocate(5);
 
    std::copy(std::begin(s), std::end(s),
              std::raw_storage_iterator<std::string*, std::string>(p));
 
    for (std::string* i = p; i != p + 5; ++i)
    {
        std::cout << *i << '\n';
        i->~basic_string<char>();
    }
    std::allocator<std::string>().deallocate(p, 5);
}

出力

This
is
a
test
.

[編集] 関連項目

アロケータ型に関する情報を提供します
(クラステンプレート) [編集]
多階層コンテナのための多階層アロケータを実装します
(クラステンプレート) [編集]
指定された型が uses-allocator 構築をサポートしているかどうかをチェックします
(クラステンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)