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

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

[编辑]复杂度

最坏情况为 O(size() * v.size())。

[编辑]示例

#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> 的公开成员函数)[编辑]
close