std::basic_string_view<CharT,Traits>:: find
From cppreference.net
<
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 。
复杂度
最坏情况下为 O( size() * v. size() )。
示例
运行此代码
#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>
的公共成员函数)
|