Namensräume
Varianten
Aktionen

std::basic_string<CharT,Traits,Allocator>::append_range

Von cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
 
template< container-compatible-range<CharT> R >
constexpr std::basic_string& append_range( R&& rg );
(seit C++23)

Hängt alle Zeichen aus dem Bereich rg an.

Äquivalent zu

return append(std::basic_string( std::from_range, std​::​forward<R>(rg), get_allocator()));

Inhalt

[bearbeiten] Parameter

rg - Ein container-kompatibler Bereich

[bearbeiten] Rückgabewert

*this

[bearbeiten] Komplexität

Linear zur Größe von rg.

[bearbeiten] Ausnahmen

Wenn die Operation dazu führen würde, dass size() max_size() überschreitet, wird std::length_error ausgelöst.

Wenn aus irgendeinem Grund eine Ausnahme ausgelöst wird, hat diese Funktion keine Auswirkungen (starkes Ausnahmesicherheitsgarantie).

[bearbeiten] Hinweise

Feature-Test-Makro Wert Std Feature
__cpp_lib_containers_ranges 202202L (C++23) Member-Funktionen, die container-kompatible Bereiche akzeptieren

[bearbeiten] Beispiel

#include <cassert>
#include <string>
 
int main()
{
    std::string head{"long long"};
    const auto tail = {' ', 'i', 'n', 't'};
 
#ifdef __cpp_lib_containers_ranges
    head.append_range(tail);
#else
    head.append(tail.begin(), tail.end());
#endif
 
    assert(head == "long long int");
}

[bearbeiten] Siehe auch

hängt Zeichen am Ende an
(public member function) [edit]