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)constnoexcept; | (1) | (C++17 起) |
constexpr size_type find( CharT ch, size_type pos =0)constnoexcept; | (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(){usingnamespace std::literals; constexprauto 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> 的公开成员函数) |