std::basic_string_view<CharT,Traits>::rfind
来自cppreference.com
<tbody>
</tbody>
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) 在此视图中寻找
v 的最后一次出现,从位置 pos 开始。2) 等价于
rfind(basic_string_view(std::addressof(c), 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> 的公开成员函数)
|