std::basic_string<CharT,Traits,Allocator>:: assign_range
|
template
<
container-compatible-range
<
CharT
>
R
>
constexpr std:: basic_string & assign_range ( R && rg ) ; |
(depuis C++23) | |
Remplace le contenu de la chaîne par les valeurs dans la plage rg .
Équivalent à
return assign( std::basic_string( std::from_range, std::forward<R>(rg), get_allocator()) );
` et contient des termes spécifiques au C++. Seul le texte environnant aurait été traduit, mais dans ce cas, il n'y a pas de texte à traduire en dehors du code.
Table des matières |
Paramètres
| rg | - | une plage compatible avec les conteneurs |
Valeur de retour
* this
Complexité
Linéaire en taille de rg .
Exceptions
Si l'opération devait entraîner le dépassement de
size()
au-delà de
max_size()
, lève
std::length_error
.
Si une exception est levée pour quelque raison que ce soit, cette fonction n'a aucun effet ( garantie forte de sécurité face aux exceptions ).
Notes
| Macro de test de fonctionnalité | Valeur | Std | Fonctionnalité |
|---|---|---|---|
__cpp_lib_containers_ranges
|
202202L
|
(C++23) | Fonctions membres acceptant container compatible range |
Exemple
#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"); }
Voir aussi
|
assigner des caractères à une chaîne
(fonction membre publique) |
|
|
assigne des valeurs à la chaîne
(fonction membre publique) |
|
construit un
basic_string
(fonction membre publique) |