std::basic_string_view<CharT,Traits>:: rfind
|
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 로 전달되면 전체 문자열이 검색됩니다.
목차 |
매개변수
| 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)
|