std::basic_string<CharT,Traits,Allocator>::basic_string
(1) | ||
basic_string(); explicit basic_string( const Allocator& alloc ); |
(C++17 前) | |
basic_string() noexcept(noexcept( Allocator() )) : basic_string( Allocator() ) {} |
(C++17 起) (C++20 前) |
|
constexpr basic_string() noexcept(noexcept( Allocator() )) : basic_string( Allocator() ) {} |
(C++20 起) | |
(2) | ||
basic_string( size_type count, CharT ch, const Allocator& alloc = Allocator() ); |
(C++20 前) | |
constexpr basic_string( size_type count, CharT ch, const Allocator& alloc = Allocator() ); |
(C++20 起) | |
(3) | ||
basic_string( const basic_string& other, size_type pos, const Allocator& alloc = Allocator() ); |
(C++20 前) | |
constexpr basic_string( const basic_string& other, size_type pos, const Allocator& alloc = Allocator() ); |
(C++20 起) | |
(3) | ||
basic_string( const basic_string& other, size_type pos, size_type count, |
(C++20 前) | |
constexpr basic_string( const basic_string& other, size_type pos, size_type count, |
(C++20 起) | |
(4) | ||
basic_string( const CharT* s, size_type count, const Allocator& alloc = Allocator() ); |
(C++20 前) | |
constexpr basic_string( const CharT* s, size_type count, const Allocator& alloc = Allocator() ); |
(C++20 起) | |
(5) | ||
basic_string( const CharT* s, const Allocator& alloc = Allocator() ); |
(C++20 前) | |
constexpr basic_string( const CharT* s, const Allocator& alloc = Allocator() ); |
(C++20 起) | |
(6) | ||
template< class InputIt > basic_string( InputIt first, InputIt last, |
(C++20 前) | |
template< class InputIt > constexpr basic_string( InputIt first, InputIt last, |
(C++20 起) | |
(7) | ||
basic_string( const basic_string& other ); |
(C++20 前) | |
constexpr basic_string( const basic_string& other ); |
(C++20 起) | |
(7) | ||
basic_string( const basic_string& other, const Allocator& alloc ); |
(C++11 起) (C++20 前) |
|
constexpr basic_string( const basic_string& other, const Allocator& alloc ); |
(C++20 起) | |
(8) | ||
basic_string( basic_string&& other ) noexcept; |
(C++11 起) (C++20 前) |
|
constexpr basic_string( basic_string&& other ) noexcept; |
(C++20 起) | |
(8) | ||
basic_string( basic_string&& other, const Allocator& alloc ); |
(C++11 起) (C++20 前) |
|
constexpr basic_string( basic_string&& other, const Allocator& alloc ); |
(C++20 起) | |
(9) | ||
basic_string( std::initializer_list<CharT> ilist, const Allocator& alloc = Allocator() ); |
(C++11 起) (C++20 前) |
|
constexpr basic_string( std::initializer_list<CharT> ilist, const Allocator& alloc = Allocator() ); |
(C++20 起) | |
(10) | ||
template< class StringViewLike > explicit basic_string( const StringViewLike& t, |
(C++17 起) (C++20 前) |
|
template< class StringViewLike > explicit constexpr basic_string( const StringViewLike& t, |
(C++20 起) | |
(11) | ||
template< class StringViewLike > basic_string( const StringViewLike& t, size_type pos, size_type n, |
(C++17 起) (C++20 前) |
|
template< class StringViewLike > constexpr basic_string( const StringViewLike& t, size_type pos, size_type n, |
(C++20 起) | |
basic_string( std::nullptr_t ) = delete; |
(12) | (C++23 起) |
从各种数据源构造新字符串,可以使用用户提供的分配器 alloc。
[
pos,
pos + count)
构造字符串。如果 count == npos 或未指定 count,或请求的子串越过字符串的结尾,那么产生的子串是 [
pos,
other.size())
。[
s,
s + count)
不是合法范围时行为未定义。[
s,
s + Traits::length(s))
不是合法范围(例如 s 是空指针),那么行为未定义。如果推导出的 Allocator
类型不满足分配器要求,那么此构造函数不会用于类模板实参推导。 (C++17 起)[
first,
last)
内容的字符串。
如果 |
(C++11 前) |
此构造函数只有在 |
(C++11 起) |
std::basic_string_view<CharT, Traits>> 是 true 且 std::is_convertible_v<const StringViewLike&, const CharT*> 是 false 时才会参与重载决议。
[
pos,
pos + n)
初始化字符串。std::basic_string_view<CharT, Traits>> 是 true 时才会参与重载决议。
std::basic_string
。参数
alloc | - | 用于此字符串所有内存分配的分配器 |
count | - | 产生的字符串大小 |
ch | - | 初始化字符串所用的值 |
pos | - | 要包含的首字符位置 |
first, last | - | 复制字符的来源范围 |
s | - | 指向用作源初始化字符串的字符数组的指针 |
other | - | 用作源初始化字符串的另一字符串 |
ilist | - | 初始化字符串所用的 std::initializer_list |
t | - | 初始化字符串所用的对象(可转换到 std::basic_string_view) |
复杂度
异常
如果构造的字符串长度会超出 max_size()(例如对于 (2),如果 count > max_size()),那么就会抛出 std::length_error。调用 Allocator::allocate
可能会抛出。
如果因为任何原因抛出了异常,那么此函数无效果(强异常安全保证)。
注意
以含内嵌 '\0' 字符的字符串字面量初始化字符串会使用重载 (5),并在首个空字符停止。这可通过指定不同的构造函数,或通过使用 operator""s
避免:
std::string s1 = "ab\0\0cd"; // s1 含 "ab" std::string s2{"ab\0\0cd", 6}; // s2 含 "ab\0\0cd" std::string s3 = "ab\0\0cd"s; // s3 含 "ab\0\0cd"
示例
#include <iostream> #include <iomanip> #include <cassert> #include <iterator> #include <string> #include <cctype> 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'; // 未指定 std::cout << "2) string(size_type count, charT ch): "; std::string s2(4, '='); std::cout << std::quoted(s2) << '\n'; // "====" std::cout << "3) string(const string& other, size_type pos, size_type count): "; std::string const other3("Exemplary"); std::string s3(other3, 0, other.length() - 1); std::cout << quoted(s3) << '\n'; // "Exemplar" std::cout << "4) string(const string& other, size_type pos): "; std::string const other4("Mutatis Mutandis"); std::string s4(other4, 8); std::cout << quoted(s4) << '\n'; // "Mutandis",即 [8, 16) std::cout << "5) string(charT const* s, size_type count): "; std::string s5("C-style string", 7); std::cout << quoted(s5) << '\n'; // "C-style",即 [0, 7) std::cout << "6) string(charT const* s): "; std::string s6("C-style\0string"); std::cout << quoted(s6) << '\n'; // "C-style" std::cout << "7) string(InputIt first, InputIt last): "; char mutable_c_str[] = "another C-style string"; std::string s7(std::begin(mutable_c_str) + 8, std::end(mutable_c_str) - 1); std::cout << quoted(s7) << '\n'; // "C-style string" std::cout << "8) string(string&): "; std::string const other8("Exemplar"); std::string s8(other); std::cout << quoted(s8) << '\n'; // "Exemplar" std::cout << "9) string(string&&): "; std::string s9(std::string("C++ by ") + std::string("example")); std::cout << quoted(s9) << '\n'; // "C++ by example" std::cout << "a) string(std::initializer_list<charT>): "; std::string sa({'C', '-', 's', 't', 'y', 'l', 'e'}); std::cout << quoted(sa) << '\n'; // "C-style" // 在 C++11 前,重载决议会选择 string(InputIt first, InputIt last) // [其中 InputIt = int],它会表现*如同* string(size_type count, charT ch) // 在 C++11 后,对整数类型参数的构造函数调用会禁用使用 InputIt 的构造函数: std::cout << "b) string(size_type count, charT ch) is called: "; std::string sb(3, std::toupper('a')); std::cout << quoted(sb) << '\n'; // "AAA" [[maybe_unused]] auto zero = [] { /* ... */ return nullptr; }; // std::string sc{zero()}; // C++23 前:抛出 std::logic_error // C++23 后:不会编译,见重载 (12) }
可能的输出:
1) string(); s1.capacity(): 15 2) string(size_type count, charT ch): "====" 3) string(const string& other, size_type pos, size_type count): "Exemplar" 4) string(const string& other, size_type pos): "Mutandis" 5) string(charT const* s, size_type count): "C-style" 6) string(charT const* s): "C-style" 7) string(InputIt first, InputIt last): "C-style string" 8) string(string&): "Exemplar" 9) string(string&&): "C++ by example" a) string(std::initializer_list<charT>): "C-style" b) string(size_type count, charT ch) is called: "AAA"
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
---|---|---|---|
LWG 301 | C++98 | 重载 (6) 在 InputIt 是整数类型时不会使用形参 alloc
|
使用该形参 |
LWG 847 | C++98 | 没有异常安全保证 | 添加强异常安全保证 |
LWG 2193 | C++11 | 默认构造函数是显式的 | 改成非显式的 |
LWG 2583 | C++98 | 无法向 basic_string(str, pos) 提供分配器
|
添加构造函数 basic_string(str, pos, alloc)
|
LWG 2946 | C++17 | 重载 (10) 在一些情况下会导致歧义 | 通过改成模板来避免 |
LWG 3076 | C++17 | 两个构造函数可能会在类模板实参推导中导致歧义 | 已制约 |
参阅
赋值字符给字符串 (公开成员函数) | |
为字符串赋值 (公开成员函数) | |
(C++11) |
转换整数或浮点值为 string (函数) |
(C++11) |
转换整数或浮点值为 wstring (函数) |
构造 basic_string_view ( std::basic_string_view<CharT,Traits> 的公开成员函数) |