std::inplace_vector<T,N>::unchecked_emplace_back
From cppreference.com
< cpp | container | inplace vector
| template< class... Args > constexpr reference unchecked_emplace_back( Args&&... args ); |
(C++26以降) | |
コンテナの末尾に新しい要素を追加します。通常、要素は、コンテナによって提供される場所にインプレースで構築するために、配置-newを使用して構築されます。引数 args... は、コンストラクタに std::forward<Args>(args)... として転送されます。 return *try_emplace_back(std::forward<Args>(args)...);と同等です。
この関数を呼び出す前に、size() < capacity() が true である必要があります。そうでない場合、動作は未定義です。
挿入が発生した場合を除く、end() 以外のイテレータや参照は無効になりません。
目次 |
[編集] Parameters
| args | - | 要素のコンストラクタに転送する引数 |
| 型要件 | ||
-T は、 std::forward<Args>(args)... から EmplaceConstructible である必要があります。 | ||
[編集] Return value
back()、つまり挿入された要素への参照。
[編集] Complexity
定数。
[編集] Exceptions
挿入される要素の初期化によってスローされる例外。例外が何らかの理由でスローされた場合、この関数は効果がありません(strong exception safety guarantee)。
[編集] Notes
| このセクションは未完成です 理由: このAPIの目的を説明します。 |
[編集] Example
このコードを実行
#include <inplace_vector> #include <new> #include <print> #include <string> #include <utility> int main() { std::inplace_vector<std::pair<std::string, std::string>, 2> fauna; std::string dog{"\N{DOG}"}; fauna.unchecked_emplace_back("\N{CAT}", dog); fauna.unchecked_emplace_back("\N{CAT}", std::move(dog)); std::println("fauna = {}", fauna); // fauna.unchecked_emplace_back("BUG", "BUG"); // undefined behavior: no space }
出力
fauna = [("🐈", "🐕"), ("🐈", "🐕")][編集] See also
| 末尾に要素を直接構築する (公開メンバ関数) | |
| 末尾に要素の範囲を追加する (公開メンバ関数) | |
| 末尾に要素を追加する (公開メンバ関数) | |
| 末尾に要素を追加しようと試みる (public member function) | |
| 末尾に要素を直接構築しようと試みる (public member function) | |
| 末尾に要素の範囲を追加しようと試みる (public member function) | |
| 末尾に要素を無条件で追加する (public member function) | |
| 最後の要素を削除する (公開メンバ関数) | |
| 引数から推論された型の std::back_insert_iterator を作成する (関数テンプレート) |