Difference between revisions of "cpp/string/basic string/basic string"
m (@10@ fix (2) => (3).) |
(Overhauled the description: 1. Rearranged the overloads (including the example). 2. Merged preconditions from the container requirements. 3. Added LWG438 DR.) |
||
Line 2: | Line 2: | ||
{{cpp/string/basic_string/navbar}} | {{cpp/string/basic_string/navbar}} | ||
{{dcl begin}} | {{dcl begin}} | ||
− | {{dcl rev | + | {{dcl rev begin|num=1}} |
− | basic_string() | + | {{dcla|since=c++11|until=c++17| |
− | + | basic_string() : basic_string(Allocator()) {} | |
+ | }} | ||
+ | {{dcla|since=c++17|constexpr=c++20| | ||
basic_string() noexcept(noexcept(Allocator())) | basic_string() noexcept(noexcept(Allocator())) | ||
− | : basic_string( Allocator() ) {} | + | : basic_string(Allocator()) {} |
}} | }} | ||
− | {{dcl|num=2 | + | {{dcl rev end}} |
+ | {{dcl rev begin|num=2}} | ||
+ | {{dcla|until=c++11|1= | ||
+ | explicit basic_string( const Allocator& alloc = Allocator() ); | ||
+ | }} | ||
+ | {{dcla|noexcept=c++17|constexpr=c++20| | ||
explicit basic_string( const Allocator& alloc ); | explicit basic_string( const Allocator& alloc ); | ||
}} | }} | ||
− | {{dcla|num=3| | + | {{dcl rev end}} |
+ | {{dcla|num=3|constexpr=c++20|1= | ||
basic_string( size_type count, CharT ch, | basic_string( size_type count, CharT ch, | ||
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=4|constexpr=c++20|1= |
− | basic_string( | + | template< class InputIt > |
+ | basic_string( InputIt first, InputIt last, | ||
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
{{dcl|num=5|since=c++23|1= | {{dcl|num=5|since=c++23|1= | ||
− | constexpr basic_string( | + | template< container-compatible-range<CharT> R > |
− | const Allocator& | + | constexpr basic_string( std::from_range_t, R&& rg, |
+ | const Allocator& = Allocator()); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=6|constexpr=c++20|1= |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | constexpr | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
basic_string( const CharT* s, size_type count, | basic_string( const CharT* s, size_type count, | ||
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{dcla|num= | + | {{dcla|num=7|constexpr=c++20|1= |
basic_string( const CharT* s, const Allocator& alloc = Allocator() ); | basic_string( const CharT* s, const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{ | + | {{dcl|num=8|since=c++23|1= |
− | template< class | + | basic_string( std::nullptr_t ) = delete; |
− | basic_string( | + | }} |
+ | {{dcla|num=9|since=c++17|constexpr=c++20|1= | ||
+ | template< class StringViewLike > | ||
+ | explicit basic_string( const StringViewLike& t, | ||
+ | const Allocator& alloc = Allocator() ); | ||
+ | }} | ||
+ | {{dcl|num=10|since=c++17|constexpr=c++20|1= | ||
+ | template< class StringViewLike > | ||
+ | basic_string( const StringViewLike& t, | ||
+ | size_type pos, size_type count, | ||
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=11|constexpr=c++20| |
basic_string( const basic_string& other ); | basic_string( const basic_string& other ); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=12|since=c++11|constexpr=c++20| |
+ | basic_string( basic_string&& other ) noexcept; | ||
+ | }} | ||
+ | {{dcla|num=13|since=c++11|constexpr=c++20| | ||
basic_string( const basic_string& other, const Allocator& alloc ); | basic_string( const basic_string& other, const Allocator& alloc ); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=14|since=c++11|constexpr=c++20| |
− | + | ||
− | + | ||
− | + | ||
basic_string( basic_string&& other, const Allocator& alloc ); | basic_string( basic_string&& other, const Allocator& alloc ); | ||
}} | }} | ||
− | {{ | + | {{dcla|num=15|constexpr=c++20|1= |
− | basic_string( | + | basic_string( const basic_string& other, size_type pos, |
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{ | + | {{dcl|num=16|since=c++23|1= |
− | + | constexpr basic_string( basic_string&& other, size_type pos, | |
− | + | const Allocator& alloc = Allocator() ); | |
− | + | ||
}} | }} | ||
− | {{ | + | {{dcla|num=17|constexpr=c++20|1= |
− | + | basic_string( const basic_string& other, | |
− | basic_string( const | + | size_type pos, size_type count, |
const Allocator& alloc = Allocator() ); | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
{{dcl|num=18|since=c++23|1= | {{dcl|num=18|since=c++23|1= | ||
− | basic_string( | + | constexpr basic_string( basic_string&& other, |
+ | size_type pos, size_type count, | ||
+ | const Allocator& alloc = Allocator() ); | ||
}} | }} | ||
− | {{dcla|num=19|since=c++ | + | {{dcla|num=19|since=c++11|constexpr=c++20|1= |
− | + | basic_string( std::initializer_list<CharT> ilist, | |
− | + | const Allocator& alloc = Allocator() ); | |
− | + | ||
}} | }} | ||
{{dcl end}} | {{dcl end}} | ||
Line 83: | Line 92: | ||
Constructs new string from a variety of data sources and optionally using user supplied allocator {{c|alloc}}. | Constructs new string from a variety of data sources and optionally using user supplied allocator {{c|alloc}}. | ||
− | @1 | + | @1@ The default constructor since C++11. Constructs an empty string with a default-constructed allocator. |
− | @3@ Constructs | + | @@ If Allocator is not {{named req|DefaultConstructible}}, the behavior is undefined. |
− | @4 | + | |
− | @ | + | @2@ The default constructor until C++11. Constructs an empty string with the given allocator {{c|alloc}}. |
− | @ | + | |
− | @ | + | @3@ Constructs a string with {{c|count}} copies of character {{c|ch}}. |
− | {{ | + | {{rev begin}} |
− | + | {{rev|since=c++11| | |
− | | | + | If {{tt|CharT}} is not {{named req|CopyInsertable}} into {{c/core|std::basic_string<CharT>}}, the behavior is undefined. |
− | @11 | + | }} |
− | + | {{rev|since=c++17| | |
− | @ | + | {{cpp/enable if|{{tt|Allocator}} satisfies the requirements of {{named req|Allocator}}}}. |
− | + | }} | |
− | @ | + | {{rev end}} |
− | @ | + | |
− | @ | + | @4@ Constructs a string with the contents of the range {{range|first|last}}. Each iterator in {{range|first|last}} is dereferenced exactly once. |
+ | {{rev begin}} | ||
+ | {{rev|until=c++11| | ||
+ | If {{tt|InputIt}} does not satisfy the requirements of {{named req|InputIterator}}, overload {{v|3}} is called instead with arguments {{c|static_cast<size_type>(first)}}, {{c|last}} and {{c|alloc}}. | ||
+ | }} | ||
+ | {{rev|since=c++11| | ||
+ | {{cpp/enable if|{{tt|InputIt}} satisfies the requirements of {{named req|InputIterator}}}}. | ||
+ | |||
+ | If {{tt|CharT}} is not {{named req|EmplaceConstructible}} into {{c/core|std::basic_string<CharT>}} from {{c|*first}}, the behavior is undefined. | ||
+ | }} | ||
+ | {{rev end}} | ||
+ | |||
+ | @5@ Constructs a string with the contents of the range {{c|rg}}. Each iterator in {{c|rg}} is dereferenced exactly once. | ||
+ | @@ If {{tt|CharT}} is not {{named req|EmplaceConstructible}} into {{c/core|std::basic_string<CharT>}} from {{c|*ranges::begin(rg)}}, the behavior is undefined. | ||
+ | |||
+ | @6@ Constructs a string with the contents of the range {{range|s|s + count}}. | ||
+ | @@ If {{range|s|s + count}} is not a valid range, the behavior is undefined. | ||
+ | |||
+ | @7@ Equivalent to {{c|basic_string(s, Traits::length(s), alloc)}}. | ||
+ | {{rrev|since=c++17| | ||
+ | {{cpp/enable if|{{tt|Allocator}} satisfies the requirements of {{named req|Allocator}}}}. | ||
+ | }} | ||
+ | |||
+ | @8@ {{tt|std::basic_string}} cannot be constructed from {{c|nullptr}}. | ||
+ | |||
+ | @9@ {{cpp/string/sv hack|constructs a string as if by {{c|basic_string(sv.data(), sv.size(), alloc)}}}} | ||
+ | |||
+ | @10@ {{cpp/string/sv hack|checkptr=no|constructs a string as if by {{c|basic_string(sv.substr(pos, n), alloc)}}}} | ||
+ | |||
+ | @11-18@ Constructs a string with (part of) the contents of {{c|other}}. If the type of {{c|other}} is {{tt|basic_string&&}}, when the construction finishes, {{c|other}} is in a valid but unspecified state. | ||
+ | |||
+ | :@11@ The copy constructor. | ||
+ | {{rrev|since=c++11| | ||
+ | The allocator is obtained as if by calling {{c multi|std::allocator_traits<Allocator>::| select_on_container_copy_construction| (other.get_allocator())}}. | ||
+ | }} | ||
+ | |||
+ | :@12@ The move constructor. The allocator is obtained by move construction from {{c|other.get_allocator()}}. | ||
+ | |||
+ | :@13@ Same as the copy constructor, except that {{c|alloc}} is used as the allocator. | ||
+ | :@@ If {{tt|CharT}} is not {{named req|CopyInsertable}} into {{c/core|std::basic_string<CharT>}}, the behavior is undefined. | ||
+ | |||
+ | :@14@ Same as the move constructor, except that {{c|alloc}} is used as the allocator. | ||
+ | :@@ If {{tt|CharT}} is not {{named req|MoveInsertable}} into {{c/core|std::basic_string<CharT>}}, the behavior is undefined. | ||
+ | |||
+ | :@15,16@ Constructs a string with the contents of the range {{range|other.data() + pos|other.data() + other.size()}}. | ||
+ | |||
+ | :@17,18@ Constructs a string with the contents of the range {{range|other.data() + pos|other.data() + (pos + std::min(count, other.size() - pos))}}. | ||
+ | |||
+ | @19@ Equivalent to {{c|basic_string(ilist.begin(), ilist.end())}}. | ||
===Parameters=== | ===Parameters=== | ||
Line 111: | Line 168: | ||
{{par|ilist|{{lc|std::initializer_list}} to initialize the string with}} | {{par|ilist|{{lc|std::initializer_list}} to initialize the string with}} | ||
{{par|t|object (convertible to {{lc|std::basic_string_view}}) to initialize the string with}} | {{par|t|object (convertible to {{lc|std::basic_string_view}}) to initialize the string with}} | ||
− | {{par|rg|a | + | {{par|rg|a container compatible range}} |
{{par end}} | {{par end}} | ||
===Complexity=== | ===Complexity=== | ||
@1,2@ Constant. | @1,2@ Constant. | ||
− | @3- | + | |
− | @9@ Linear in | + | @3-7@ Linear in the size of the string. |
− | @ | + | |
− | @ | + | @9-11@ Linear in the size of the string. |
− | + | ||
− | @14@ | + | @12@ Constant. |
− | + | ||
− | + | @13@ Linear in the size of the string. | |
− | @ | + | |
− | + | @14@ Linear in the size of the string if {{c|1=alloc != other.get_allocator()}} is {{c|true}}, otherwise constant. | |
+ | |||
+ | @15-19@ Linear in the size of the string. | ||
===Exceptions=== | ===Exceptions=== | ||
− | @ | + | @10@ {{lc|std::out_of_range}} if {{c|pos}} is out of range. |
− | + | ||
− | @14@ Throws nothing if {{c|1=alloc == str.get_allocator()}}. | + | @14@ Throws nothing if {{c|1=alloc == str.get_allocator()}} is {{c|true}}. |
− | @ | + | |
+ | @15-18@ {{lc|std::out_of_range}} if {{c|pos > other.size()}}. | ||
− | Throws {{lc|std::length_error}} if the length of the constructed string would exceed {{lc|max_size()}} (for example, if {{c|count > max_size()}} for {{ | + | Throws {{lc|std::length_error}} if the length of the constructed string would exceed {{lc|max_size()}} (for example, if {{c|count > max_size()}} for {{v|3}}). Calls to {{tt|Allocator::allocate}} may throw. |
{{cpp/strong exception safety guarantee|plural=yes}} | {{cpp/strong exception safety guarantee|plural=yes}} | ||
===Notes=== | ===Notes=== | ||
− | Initialization with a | + | Initialization with a {{lt|cpp/language/string literal}} that contains embedded {{c|'\0'}} characters uses the overload {{v|7}}, which stops at the first null character. This can be avoided by specifying a different constructor or by using {{rlpt|operator""s}}: |
{{source|1= | {{source|1= | ||
std::string s1 = "ab\0\0cd"; // s1 contains "ab" | std::string s1 = "ab\0\0cd"; // s1 contains "ab" | ||
Line 145: | Line 205: | ||
}} | }} | ||
− | {{feature test macro|__cpp_lib_containers_ranges|value=202202L|std=C++23|Tagged constructor {{ | + | {{feature test macro|__cpp_lib_containers_ranges|value=202202L|std=C++23|Tagged constructor {{v|5}} to construct from {{ls|cpp/ranges/to#container compatible range}}}} |
===Example=== | ===Example=== | ||
Line 159: | Line 219: | ||
int main() | int main() | ||
{ | { | ||
− | std::cout << "1) string(); "; | + | std::cout << "1) string(); "; |
std::string s1; | std::string s1; | ||
assert(s1.empty() && (s1.length() == 0) && (s1.size() == 0)); | assert(s1.empty() && (s1.length() == 0) && (s1.size() == 0)); | ||
std::cout << "s1.capacity(): " << s1.capacity() << '\n'; // unspecified | std::cout << "s1.capacity(): " << s1.capacity() << '\n'; // unspecified | ||
− | + | ||
− | std::cout << " | + | std::cout << "3) string(size_type count, CharT ch): "; |
std::string s2(4, '='); | std::string s2(4, '='); | ||
std::cout << std::quoted(s2) << '\n'; // "====" | std::cout << std::quoted(s2) << '\n'; // "====" | ||
− | + | ||
− | + | std::cout << "4) string(InputIt first, InputIt last): "; | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | std::cout << "4) | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
char mutable_c_str[] = "another C-style string"; | char mutable_c_str[] = "another C-style string"; | ||
− | std::string | + | std::string s4(std::begin(mutable_c_str) + 8, std::end(mutable_c_str) - 1); |
− | std::cout << std::quoted( | + | std::cout << std::quoted(s4) << '\n'; // "C-style string" |
− | + | ||
− | std::cout << " | + | std::cout << "6) string(CharT const* s, size_type count): "; |
− | std::string | + | std::string s6("C-style string", 7); |
− | + | std::cout << std::quoted(s6) << '\n'; // "C-style", i.e. [0, 7) | |
− | std::cout << std::quoted( | + | |
− | + | std::cout << "7) string(CharT const* s): "; | |
− | std::cout << " | + | std::string s7("C-style\0string"); |
− | std::string | + | std::cout << std::quoted(s7) << '\n'; // "C-style" |
− | std::cout << std::quoted( | + | |
− | + | std::cout << "11) string(string&): "; | |
− | std::cout << " | + | std::string const other11("Exemplar"); |
− | std::string | + | std::string s11(other11); |
− | std::cout << std::quoted( | + | std::cout << std::quoted(s11) << '\n'; // "Exemplar" |
− | + | ||
− | + | std::cout << "12) string(string&&): "; | |
− | + | std::string s12(std::string("C++ by ") + std::string("example")); | |
− | + | std::cout << std::quoted(s12) << '\n'; // "C++ by example" | |
− | std::cout << " | + | |
− | std::string | + | std::cout << "15) string(const string& other, size_type pos): "; |
− | std::cout << std::quoted( | + | std::string const other15("Mutatis Mutandis"); |
− | + | std::string s15(other15, 8); | |
− | + | std::cout << std::quoted(s15) << '\n'; // "Mutandis", i.e. [8, 16) | |
− | + | ||
− | + | std::cout << "17) string(const string& other, size_type pos, size_type count): "; | |
− | + | std::string const other17("Exemplary"); | |
− | + | std::string s17(other17, 0, other17.length() - 1); | |
− | + | std::cout << std::quoted(s17) << '\n'; // "Exemplar" | |
− | std:: | + | |
− | std::cout << " | + | std::cout << "19) string(std::initializer_list<CharT>): "; |
− | + | std::string s19({'C', '-', 's', 't', 'y', 'l', 'e'}); | |
− | std::string | + | std::cout << std::quoted(s19) << '\n'; // "C-style" |
− | std::cout << " | + | |
− | + | ||
− | std::cout << std::quoted( | + | |
} | } | ||
|p=true<!-- due to .capacity() --> | |p=true<!-- due to .capacity() --> | ||
|output= | |output= | ||
− | 1) string(); s1.capacity(): 15 | + | 1) string(); s1.capacity(): 15 |
− | + | 3) string(size_type count, CharT ch): "====" | |
− | + | 4) string(InputIt first, InputIt last): "C-style string" | |
− | + | 6) string(CharT const* s, size_type count): "C-style" | |
− | + | 7) string(CharT const* s): "C-style" | |
− | + | 11) string(string&): "Exemplar" | |
− | + | 12) string(string&&): "C++ by example" | |
− | + | 15) string(const string& other, size_type pos): "Mutandis" | |
− | + | 17) string(const string& other, size_type pos, size_type count): "Exemplar" | |
− | + | 19) string(std::initializer_list<CharT>): "C-style" | |
− | + | ||
− | + | ||
}} | }} | ||
===Defect reports=== | ===Defect reports=== | ||
{{dr list begin}} | {{dr list begin}} | ||
− | {{dr list item|wg=lwg|dr=301|std=C++98|before=overload {{ | + | {{dr list item|wg=lwg|dr=301|std=C++98|before=overload {{v|4}} did not use the parameter<br>{{c|alloc}} if {{tt|InputIt}} is an integral type|after=use that parameter}} |
+ | {{dr list item|wg=lwg|dr=438|std=C++98|before=overload {{v|4}} would only call overload {{v|3}}<br>if {{tt|InputIt}} is an integral type|after=calls overload {{v|3}} if {{tt|InputIt}}<br>is not an {{named req|InputIterator}}}} | ||
{{dr list item|wg=lwg|dr=847|std=C++98|before=there was no exception safety guarantee|after=added strong exception safety guarantee}} | {{dr list item|wg=lwg|dr=847|std=C++98|before=there was no exception safety guarantee|after=added strong exception safety guarantee}} | ||
{{dr list item|wg=lwg|dr=2193|std=C++11|before=the default constructor is explicit|after=made non-explicit}} | {{dr list item|wg=lwg|dr=2193|std=C++11|before=the default constructor is explicit|after=made non-explicit}} | ||
− | {{dr list item|wg=lwg|dr=2583|std=C++98|before=there | + | {{dr list item|wg=lwg|dr=2583|std=C++98|before=there was no way to supply an allocator for overload {{v|17}}|after=added overload {{v|15}}}} |
− | {{dr list item|wg=lwg|dr=2946|std=C++17|before=overload {{ | + | {{dr list item|wg=lwg|dr=2946|std=C++17|before=overload {{v|9}} causes ambiguity in some cases|after=avoided by making it a template}} |
− | {{dr list item|wg=lwg|dr=3076|std=C++17|before= | + | {{dr list item|wg=lwg|dr=3076|std=C++17|before=overloads {{v|3,7}} might cause ambiguities<br>in class template argument deduction|after=constrained}} |
{{dr list end}} | {{dr list end}} | ||
Latest revision as of 00:07, 12 November 2024
(1) | ||
basic_string() : basic_string(Allocator()) {} |
(since C++11) (until C++17) |
|
basic_string() noexcept(noexcept(Allocator())) : basic_string(Allocator()) {} |
(since C++17) (constexpr since C++20) |
|
(2) | ||
explicit basic_string( const Allocator& alloc = Allocator() ); |
(until C++11) | |
explicit basic_string( const Allocator& alloc ); |
(noexcept since C++17) (constexpr since C++20) |
|
basic_string( size_type count, CharT ch, const Allocator& alloc = Allocator() ); |
(3) | (constexpr since C++20) |
template< class InputIt > basic_string( InputIt first, InputIt last, |
(4) | (constexpr since C++20) |
template< container-compatible-range<CharT> R > constexpr basic_string( std::from_range_t, R&& rg, |
(5) | (since C++23) |
basic_string( const CharT* s, size_type count, const Allocator& alloc = Allocator() ); |
(6) | (constexpr since C++20) |
basic_string( const CharT* s, const Allocator& alloc = Allocator() ); |
(7) | (constexpr since C++20) |
basic_string( std::nullptr_t ) = delete; |
(8) | (since C++23) |
template< class StringViewLike > explicit basic_string( const StringViewLike& t, |
(9) | (since C++17) (constexpr since C++20) |
template< class StringViewLike > basic_string( const StringViewLike& t, |
(10) | (since C++17) |
basic_string( const basic_string& other ); |
(11) | (constexpr since C++20) |
basic_string( basic_string&& other ) noexcept; |
(12) | (since C++11) (constexpr since C++20) |
basic_string( const basic_string& other, const Allocator& alloc ); |
(13) | (since C++11) (constexpr since C++20) |
basic_string( basic_string&& other, const Allocator& alloc ); |
(14) | (since C++11) (constexpr since C++20) |
basic_string( const basic_string& other, size_type pos, const Allocator& alloc = Allocator() ); |
(15) | (constexpr since C++20) |
constexpr basic_string( basic_string&& other, size_type pos, const Allocator& alloc = Allocator() ); |
(16) | (since C++23) |
basic_string( const basic_string& other, size_type pos, size_type count, |
(17) | (constexpr since C++20) |
constexpr basic_string( basic_string&& other, size_type pos, size_type count, |
(18) | (since C++23) |
basic_string( std::initializer_list<CharT> ilist, const Allocator& alloc = Allocator() ); |
(19) | (since C++11) (constexpr since C++20) |
Constructs new string from a variety of data sources and optionally using user supplied allocator alloc.
If |
(since C++11) |
This overload participates in overload resolution only if |
(since C++17) |
[
first,
last)
. Each iterator in [
first,
last)
is dereferenced exactly once.
If |
(until C++11) |
This overload participates in overload resolution only if If |
(since C++11) |
CharT
is not EmplaceConstructible into std::basic_string<CharT> from *ranges::begin(rg), the behavior is undefined.[
s,
s + count)
.[
s,
s + count)
is not a valid range, the behavior is undefined.
This overload participates in overload resolution only if |
(since C++17) |
std::basic_string
cannot be constructed from nullptr.std::basic_string_view<CharT, Traits>> is true and std::is_convertible_v<const StringViewLike&, const CharT*> is false.
std::basic_string_view<CharT, Traits>> is true.
basic_string&&
, when the construction finishes, other is in a valid but unspecified state.
The allocator is obtained as if by calling std::allocator_traits<Allocator>:: |
(since C++11) |
[
other.data() + pos,
other.data() + other.size())
.[
other.data() + pos,
other.data() + (pos + std::min(count, other.size() - pos)))
.Contents |
[edit] Parameters
alloc | - | allocator to use for all memory allocations of this string |
count | - | size of the resulting string |
ch | - | value to initialize the string with |
pos | - | position of the first character to include |
first, last | - | range to copy the characters from |
s | - | pointer to an array of characters to use as source to initialize the string with |
other | - | another string to use as source to initialize the string with |
ilist | - | std::initializer_list to initialize the string with |
t | - | object (convertible to std::basic_string_view) to initialize the string with |
rg | - | a container compatible range |
[edit] Complexity
[edit] Exceptions
Throws std::length_error if the length of the constructed string would exceed max_size() (for example, if count > max_size() for (3)). Calls to Allocator::allocate
may throw.
If an exception is thrown for any reason, these functions have no effect (strong exception safety guarantee).
[edit] Notes
Initialization with a string literal that contains embedded '\0' characters uses the overload (7), which stops at the first null character. This can be avoided by specifying a different constructor or by using operator""s
:
std::string s1 = "ab\0\0cd"; // s1 contains "ab" std::string s2{"ab\0\0cd", 6}; // s2 contains "ab\0\0cd" std::string s3 = "ab\0\0cd"s; // s3 contains "ab\0\0cd"
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_containers_ranges |
202202L | (C++23) | Tagged constructor (5) to construct from container compatible range |
[edit] Example
#include <cassert> #include <cctype> #include <iomanip> #include <iostream> #include <iterator> #include <string> int main() { std::cout << "1) string(); "; std::string s1; assert(s1.empty() && (s1.length() == 0) && (s1.size() == 0)); std::cout << "s1.capacity(): " << s1.capacity() << '\n'; // unspecified std::cout << "3) string(size_type count, CharT ch): "; std::string s2(4, '='); std::cout << std::quoted(s2) << '\n'; // "====" std::cout << "4) string(InputIt first, InputIt last): "; char mutable_c_str[] = "another C-style string"; std::string s4(std::begin(mutable_c_str) + 8, std::end(mutable_c_str) - 1); std::cout << std::quoted(s4) << '\n'; // "C-style string" std::cout << "6) string(CharT const* s, size_type count): "; std::string s6("C-style string", 7); std::cout << std::quoted(s6) << '\n'; // "C-style", i.e. [0, 7) std::cout << "7) string(CharT const* s): "; std::string s7("C-style\0string"); std::cout << std::quoted(s7) << '\n'; // "C-style" std::cout << "11) string(string&): "; std::string const other11("Exemplar"); std::string s11(other11); std::cout << std::quoted(s11) << '\n'; // "Exemplar" std::cout << "12) string(string&&): "; std::string s12(std::string("C++ by ") + std::string("example")); std::cout << std::quoted(s12) << '\n'; // "C++ by example" std::cout << "15) string(const string& other, size_type pos): "; std::string const other15("Mutatis Mutandis"); std::string s15(other15, 8); std::cout << std::quoted(s15) << '\n'; // "Mutandis", i.e. [8, 16) std::cout << "17) string(const string& other, size_type pos, size_type count): "; std::string const other17("Exemplary"); std::string s17(other17, 0, other17.length() - 1); std::cout << std::quoted(s17) << '\n'; // "Exemplar" std::cout << "19) string(std::initializer_list<CharT>): "; std::string s19({'C', '-', 's', 't', 'y', 'l', 'e'}); std::cout << std::quoted(s19) << '\n'; // "C-style" }
Possible output:
1) string(); s1.capacity(): 15 3) string(size_type count, CharT ch): "====" 4) string(InputIt first, InputIt last): "C-style string" 6) string(CharT const* s, size_type count): "C-style" 7) string(CharT const* s): "C-style" 11) string(string&): "Exemplar" 12) string(string&&): "C++ by example" 15) string(const string& other, size_type pos): "Mutandis" 17) string(const string& other, size_type pos, size_type count): "Exemplar" 19) string(std::initializer_list<CharT>): "C-style"
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 301 | C++98 | overload (4) did not use the parameter alloc if InputIt is an integral type
|
use that parameter |
LWG 438 | C++98 | overload (4) would only call overload (3) if InputIt is an integral type
|
calls overload (3) if InputIt is not an LegacyInputIterator |
LWG 847 | C++98 | there was no exception safety guarantee | added strong exception safety guarantee |
LWG 2193 | C++11 | the default constructor is explicit | made non-explicit |
LWG 2583 | C++98 | there was no way to supply an allocator for overload (17) | added overload (15) |
LWG 2946 | C++17 | overload (9) causes ambiguity in some cases | avoided by making it a template |
LWG 3076 | C++17 | overloads (3,7) might cause ambiguities in class template argument deduction |
constrained |
[edit] See also
assign characters to a string (public member function) | |
assigns values to the string (public member function) | |
(C++11) |
converts an integral or floating-point value to string (function) |
(C++11) |
converts an integral or floating-point value to wstring (function) |
constructs a basic_string_view (public member function of std::basic_string_view<CharT,Traits> )
|