std::basic_string<CharT,Traits,Allocator>::insert_range
From cppreference.com
< cpp | string | basic string
| template< class container-compatible-range<CharT> R > constexpr iterator insert_range( const_iterator pos, R&& rg ); |
(C++23から) | |
範囲 rg から文字を、pos が指す要素(存在する場合)の前に挿入します。
以下と等価です。
return insert(pos - begin(), std::basic_string( std::from_range, std::forward<R>(rg), get_allocator()) );
pos が *this の有効なイテレータでない場合、動作は未定義です。
目次 |
[編集] パラメータ
| pos | - | 文字が挿入される、その前のイテレータ |
| rg | - | a コンテナ互換範囲 |
[編集] 戻り値
挿入された最初の文字を参照するイテレータ。または、rg が空であったため文字が挿入されなかった場合は pos。
[編集] 計算量
rg のサイズに対して線形。
[編集] 例外
std::allocator_traits<Allocator>::allocate が例外をスローした場合、それは再スローされます。
操作によりsize()がmax_size()を超える場合、std::length_errorを送出します。
何らかの理由で例外がスローされた場合、この関数は効果がありません(強力な例外安全保証)。
[編集] 注記
| 機能テストマクロ | 値 | 規格 | 機能 |
|---|---|---|---|
__cpp_lib_containers_ranges |
202202L |
(C++23) | コンテナ互換範囲を受け入れるメンバ関数 |
[編集] 例
このコードを実行
#include <cassert> #include <iterator> #include <string> int main() { const auto source = {'l', 'i', 'b', '_'}; std::string target{"__cpp_containers_ranges"}; // ^insertion will occur // before this position const auto pos = target.find("container"); assert(pos != target.npos); auto iter = std::next(target.begin(), pos); #ifdef __cpp_lib_containers_ranges target.insert_range(iter, source); #else target.insert(iter, source.begin(), source.end()); #endif assert(target == "__cpp_lib_containers_ranges"); // ^^^^ }
[編集] 関連項目
| 文字を挿入する (public member function) |