std::basic_string<CharT,Traits,Allocator>:: insert_range
| Classes | ||||
|
(C++17)
|
||||
|
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
template
<
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 | - | container compatible range |
戻り値
最初に挿入された文字を参照するイテレータ、または pos ( rg が空だったために文字が挿入されなかった場合)。
計算量
rg のサイズに対して線形。
例外
std:: allocator_traits < Allocator > :: allocate が例外をスローした場合、その例外は再スローされます。
操作によって
size()
が
max_size()
を超える場合、
std::length_error
をスローします。
何らかの理由で例外がスローされた場合、この関数は何も効果を持ちません( strong exception safety guarantee )。
注記
| 機能テスト マクロ | 値 | 標準 | 機能 |
|---|---|---|---|
__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"}; // ^挿入はこの位置の前で発生 // この位置の前で挿入が行われる 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) |