Namensräume
Varianten
Aktionen

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

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

Ersetzt den Inhalt des Strings durch die Werte im Bereich rg.

Äquivalent zu

return assign(
    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()
{
    const auto source = {'s', 'o', 'u', 'r', 'c', 'e'};
    std::string destination{"destination"};
 
#ifdef __cpp_lib_containers_ranges
    destination.assign_range(source);
#else
    destination.assign(source.begin(), source.end());
#endif
 
    assert(destination == "source");
}

[bearbeiten] Siehe auch

weist Zeichen einem String zu
(public member function) [edit]
weist dem String Werte zu
(public member function) [edit]
konstruiert einen basic_string
(public member function) [edit]