std::basic_string_view<CharT,Traits>:: rfind
From cppreference.net
<
cpp
|
string
|
basic string view
|
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')) ); }
参见
|
在视图中查找字符
(公开成员函数) |
|
|
查找字符的首次出现
(公开成员函数) |
|
|
查找字符的最后一次出现
(公开成员函数) |
|
|
查找字符的首次缺失
(公开成员函数) |
|
|
查找字符的最后一次缺失
(公开成员函数) |
|
|
查找子字符串的最后一次出现
(
std::basic_string<CharT,Traits,Allocator>
的公开成员函数)
|