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'))
    );
}

参见

在视图中查找字符
(公开成员函数)
查找字符的首次出现
(公开成员函数)
查找字符的最后一次出现
(公开成员函数)
查找字符的首次缺失
(公开成员函数)
查找字符的最后一次缺失
(公开成员函数)
查找子字符串的最后一次出现
( std::basic_string<CharT,Traits,Allocator> 的公开成员函数)