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> 的公共成員函式) |