Namespaces
Variants

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

From cppreference.net
constexpr size_type rfind ( basic_string_view v, size_type pos = npos ) const noexcept ;
(1) (C++17부터)
constexpr size_type rfind ( CharT ch, size_type pos = npos ) const noexcept ;
(2) (C++17부터)
constexpr size_type rfind ( const CharT * s, size_type pos, size_type count ) const ;
(3) (C++17부터)
constexpr size_type rfind ( const CharT * s, size_type pos = npos ) const ;
(4) (C++17부터)

주어진 문자 시퀀스와 동일한 마지막 부분 문자열을 찾습니다. 검색은 pos 에서 시작하여 오른쪽에서 왼쪽으로 진행됩니다(따라서 발견된 부분 문자열이 있는 경우, pos 이후 위치에서 시작할 수 없습니다). npos 또는 size() - 1 보다 작지 않은 값이 pos 로 전달되면 전체 문자열이 검색됩니다.

1) 이 뷰에서 위치 pos 부터 시작하여 v 의 마지막 발생을 찾습니다.
2) 다음에 해당함 rfind ( basic_string_view ( std:: addressof ( ch ) , 1 ) , pos ) .
3) 다음에 해당함: rfind ( basic_string_view ( s, count ) , pos ) .
4) 다음에 해당함: rfind ( basic_string_view ( s ) , pos ) .

목차

매개변수

v - 검색할 뷰
pos - 검색을 시작할 위치
count - 검색할 부분 문자열의 길이
s - 검색할 문자 문자열에 대한 포인터
ch - 검색할 문자

반환값

찾은 부분 문자열의 첫 번째 문자 위치 또는 npos 해당 부분 문자열이 발견되지 않은 경우.

복잡도

최악의 경우 O( size() * v. size() )입니다.

예제

#include <string_view>
int main()
{
    using namespace std::literals;
    constexpr auto N = std::string_view::npos;
    static_assert(true
        && (6 == "AB AB AB"sv.rfind("AB"))
        && (6 == "AB AB AB"sv.rfind("ABCD", N, 2))
        && (3 == "AB AB AB"sv.rfind("AB", 5))
        && (0 == "AB CD EF"sv.rfind("AB", 0))
        && (2 == "B AB AB "sv.rfind("AB", 2))
        && (N == "B AB AB "sv.rfind("AB", 1))
        && (5 == "B AB AB "sv.rfind('A'))
        && (4 == "AB AB AB"sv.rfind('B', 4))
        && (N == "AB AB AB"sv.rfind('C'))
    );
}

참고 항목

뷰에서 문자 찾기
(public member function)
문자들의 첫 번째 발생 위치 찾기
(public member function)
문자들의 마지막 발생 위치 찾기
(public member function)
문자들이 없는 첫 번째 위치 찾기
(public member function)
문자들이 없는 마지막 위치 찾기
(public member function)
부분 문자열의 마지막 발생 위치 찾기
( std::basic_string<CharT,Traits,Allocator> 의 public member function)