名稱空間
變體
操作

std::basic_string_view<CharT,Traits>::rfind

來自 cppreference.com
 
 
 
 
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

[編輯] 複雜度

最壞情況下為 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> 的公共成員函式) [編輯]