std::basic_string_view<CharT,Traits>::find
来自cppreference.com
< cpp | string | basic string view
constexpr size_type find( basic_string_view v, size_type pos = 0 ) const noexcept; |
(1) | (C++17 起) |
constexpr size_type find( CharT ch, size_type pos = 0 ) const noexcept; |
(2) | (C++17 起) |
constexpr size_type find( const CharT* s, size_type pos, size_type count ) const; |
(3) | (C++17 起) |
constexpr size_type find( const CharT* s, size_type pos = 0 ) const; |
(4) | (C++17 起) |
寻找首个等于给定字符序列的子串。
1) 在此视图中寻找 v 的首次出现,从位置
pos
开始。2) 等价于 find(basic_string_view(std::addressof(ch), 1), pos)。
3) 等价于 find(basic_string_view(s, count), pos)。
4) 等价于 find(basic_string_view(s), pos)。
参数
v | - | 要搜索的子串 |
pos | - | 要开始搜索的位置 |
count | - | 要搜索的子串长度 |
s | - | 指向要搜索的字符串的指针 |
ch | - | 要搜索的字符 |
返回值
找到的子串的首字符位置,或者若找不到子串则为 npos。
复杂度
示例
运行此代码
#include <string_view> int main() { using namespace std::literals; constexpr auto str{" long long int;"sv}; static_assert( 1 == str.find("long"sv) && "<- find(v , pos = 0)" && 6 == str.find("long"sv, 2) && "<- find(v , pos = 2)" && 0 == str.find(' ') && "<- find(ch, pos = 0)" && 2 == str.find('o', 1) && "<- find(ch, pos = 1)" && 2 == str.find("on") && "<- find(s , pos = 0)" && 6 == str.find("long double", 5, 4) && "<- find(s , pos = 5, count = 4)" ); static_assert(str.npos == str.find("float")); }
参阅
寻找子串的最后一次出现 (公开成员函数) | |
查找字符的首次出现 (公开成员函数) | |
查找字符的最后一次出现 (公开成员函数) | |
查找字符的首次不出现 (公开成员函数) | |
查找字符的最后一次不出现 (公开成员函数) | |
寻找给定子串的首次出现 ( std::basic_string<CharT,Traits,Allocator> 的公开成员函数) |