std::basic_string_view<CharT,Traits>::rfind
来自 cppreference.com
< 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) 在此视图中查找 v 的最后一次出现,从位置 pos 开始。
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。
[编辑] 复杂度
[编辑] 示例
运行此代码
#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> 的公共成员函数) |