Namespaces
Variants

std::basic_string_view<CharT,Traits>:: basic_string_view

From cppreference.net


constexpr basic_string_view ( ) noexcept ;
(1) (C++17부터)
constexpr basic_string_view ( const basic_string_view & other ) noexcept = default ;
(2) (C++17부터)
constexpr basic_string_view ( const CharT * s, size_type count ) ;
(3) (C++17부터)
constexpr basic_string_view ( const CharT * s ) ;
(4) (C++17부터)
template < class It, class End >
constexpr basic_string_view ( It first, End last ) ;
(5) (C++20부터)
template < class R >
constexpr explicit basic_string_view ( R && r ) ;
(6) (C++23부터)
basic_string_view ( std:: nullptr_t ) = delete ;
(7) (C++23부터)
1) 기본 생성자. 빈 std::basic_string_view 를 생성합니다. 생성 후, data() nullptr 와 같고, size() 0 와 같습니다.
2) 복사 생성자. other 와 동일한 내용의 뷰를 생성합니다. 생성 후, data() other. data ( ) 와 동일하고, size() other. size ( ) 와 동일합니다.
3) s 가 가리키는 요소로 시작하는 문자 배열의 첫 count 개 문자에 대한 뷰를 생성합니다. s 는 널 문자를 포함할 수 있습니다. [ s , s + count ) 가 유효한 범위가 아닌 경우 동작은 정의되지 않습니다(생성자가 이 범위의 어떤 요소에도 접근하지 않을 수 있음에도 불구하고). 생성 후, data() s 와 같고, size() count 와 같습니다.
4) s 가 가리키는 널 종료 문자열의 뷰를 생성하며, 종료 널 문자는 포함하지 않습니다. 뷰의 길이는 Traits :: length ( s ) 로 결정된 것처럼 계산됩니다. [ s , s + Traits :: length ( s ) ) 가 유효한 범위가 아닌 경우 동작은 정의되지 않습니다. 생성 후, data() s 와 같고, size() Traits :: length ( s ) 와 같습니다.
5) 범위 [ first , last ) 에 대한 std::basic_string_view 를 생성합니다. [ first , last ) 가 유효한 범위가 아니거나, It 가 실제로 contiguous_iterator 를 모델링하지 않거나, End 가 실제로 It 에 대한 sized_sentinel_for 를 모델링하지 않는 경우 동작은 정의되지 않습니다. 생성 후, data() std:: to_address ( first ) 와 같고, size() last - first 와 같습니다.

이 오버로드는 다음 모든 조건이 만족될 때만 오버로드 해결에 참여합니다:

6) 범위 r 에 대해 std::basic_string_view 를 생성합니다. 생성 후, data() ranges:: data ( r ) 와 같고, size() ranges:: size ( r ) 와 같습니다.

이 오버로드는 다음 조건들이 모두 만족될 때만 오버로드 해결에 참여합니다:

7) std::basic_string_view nullptr 로부터 생성될 수 없습니다.

목차

매개변수

other - 뷰를 초기화할 다른 뷰
s - 뷰를 초기화할 문자 배열 또는 C 문자열에 대한 포인터
count - 뷰에 포함할 문자 수
first - 시퀀스의 첫 번째 문자를 가리키는 반복자
last - 시퀀스의 마지막 문자 다음을 가리키는 반복자 또는 다른 센티넬
r - 시퀀스를 포함하는 연속 범위

복잡도

1-3,5,6) 상수.
4) 길이에 대해 선형적인 s .

예제

#include <array>
#include <iomanip>
#include <iostream>
#include <string>
#include <string_view>
int main()
{
    std::string cppstr = "Foo";
    std::string_view cppstr_v(cppstr); // 오버로드 (2), 이후
                                       // std::string::operator string_view
    std::cout << "1) cppstr_v: " << std::quoted(cppstr_v) << '\n';
    char array[3] = {'B', 'a', 'r'};
    std::string_view array_v(array, std::size(array)); // 오버로드 (3)
    std::cout << "2) array_v: " << std::quoted(array_v) << '\n';
    const char* one_0_two = "One\0Two";
    std::string_view one_two_v{one_0_two, 7}; // 오버로드 (3)
    std::cout << "3) one_two_v: \"";
    for (char c : one_two_v)
        std::cout << (c != '\0' ? c : '?');
    std::cout << "\", one_two_v.size(): " << one_two_v.size() << '\n';
    std::string_view one_v{one_0_two}; // 오버로드 (4)
    std::cout << "4) one_v: " << std::quoted(one_v) << ", one_v.size(): " 
              << one_v.size() << '\n';
    constexpr std::wstring_view wcstr_v = L"xyzzy"; // 오버로드 (4)
    std::cout << "5) wcstr_v.size(): " << wcstr_v.size() << '\n';
    std::array ar = {'P', 'u', 'b'};
    std::string_view ar_v(ar.begin(), ar.end()); // 오버로드 (5), C++20
    std::cout << "6) ar_v: " << std::quoted(ar_v) << '\n';
//  std::string_view ar_v2{ar}; // 오버로드 (6), C++23에서 OK
//  std::cout << "ar_v2: " << std::quoted(ar_v2) << '\n'; // ar_v2: "Pub"
    [[maybe_unused]] auto zero = [] { /* ... */ return nullptr; };
//  std::string_view s{zero()}; // 오버로드 (7), C++23부터 컴파일되지 않음
}

출력:

1) cppstr_v: "Foo"
2) array_v: "Bar"
3) one_two_v: "One?Two", one_two_v.size(): 7
4) one_v: "One", one_v.size(): 3
5) wcstr_v.size(): 5
6) ar_v: "Pub"

참고 항목

뷰를 할당함
(public member function)
basic_string 을 생성함
( std::basic_string<CharT,Traits,Allocator> 의 public member function)