Namespaces
Variants

deduction guides for std::basic_string

From cppreference.net
std::basic_string
定义于头文件 <string>
template < class InputIt,

class Alloc = std:: allocator < typename std:: iterator_traits
< InputIt > :: value_type > >
basic_string ( InputIt, InputIt, Alloc = Alloc ( ) )
- > basic_string < typename std:: iterator_traits < InputIt > :: value_type ,
std:: char_traits
< typename std:: iterator_traits < InputIt > :: value_type > ,

Alloc > ;
(1) (C++17 起)
template < class CharT,

class Traits,
class Alloc = std:: allocator < CharT > >
explicit basic_string ( std:: basic_string_view < CharT, Traits > ,
const Alloc & = Alloc ( ) )

- > basic_string < CharT, Traits, Alloc > ;
(2) (C++17 起)
template < class CharT,

class Traits,
class Alloc = std:: allocator < CharT > >
basic_string ( std:: basic_string_view < CharT, Traits > ,
typename /* 见下文 */ :: size_type ,
typename /* 见下文 */ :: size_type ,
const Alloc & = Alloc ( ) )

- > basic_string < CharT, Traits, Alloc > ;
(3) (C++17 起)
template < ranges:: input_range R,

class Alloc = std:: allocator < ranges:: range_value_t < R >> >
basic_string ( std:: from_range_t , R && , Alloc = Alloc ( ) )
- > basic_string < ranges:: range_value_t < R > ,

std:: char_traits < ranges:: range_value_t < R >> , Alloc > ;
(4) (C++23 起)
1) 推导指引 std::basic_string 提供,允许从迭代器范围进行推导。此重载仅当 InputIt 满足 LegacyInputIterator Alloc 满足 Allocator 时参与重载决议。
2,3) 这些推导指南为 std::basic_string 提供,允许从 std::basic_string_view 进行推导。这些重载仅在 Alloc 满足 Allocator 要求时参与重载决议。
3) size_type 参数类型指代由推导指南推导出的类型中的嵌套类型 size_type
4) 此推导指南为 std::basic_string 提供,允许从 std::from_range_t 标签和 input_range 进行推导。

注意:库判定某个类型不满足 LegacyInputIterator 要求的程度是未指定的,但至少整型类型不符合输入迭代器的要求。同样地,库判定某个类型不满足 Allocator 要求的程度也是未指定的,但至少成员类型 Alloc::value_type 必须存在,且表达式 std:: declval < Alloc & > ( ) . allocate ( std:: size_t { } ) 在作为未求值操作数处理时必须良构。

目录

注释

需要推导指引 ( 2,3 ) 是因为 std::basic_string 针对 std::basic_string_view 的构造函数被实现为模板,以避免在现有代码中引发歧义,而这些模板不支持类模板实参推导。

注释

功能测试 标准 功能
__cpp_lib_containers_ranges 202202L (C++23) 范围感知 的构造与插入;重载 ( 4 )

示例

#include <cassert>
#include <string>
#include <vector>
int main()
{
    std::vector<char> v = {'a', 'b', 'c'};
    std::basic_string s1(v.begin(), v.end()); // 使用推导指南 (1)
    assert(s1 == "abc");
#if __cpp_lib_containers_ranges >= 202202L
    std::vector<wchar_t> v4{0x43, 43, 053, 0x32, 0x33};
    std::basic_string s4(std::from_range, v4); // 使用推导指南 (4)
    assert(s4 == L"C++23");
#endif
}

缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的C++标准。

缺陷报告 适用范围 发布时行为 正确行为
LWG 3075 C++17 不支持从 basic_string_view 进行推导
(因 LWG 问题 2946 加剧)
已添加推导指南