Namespaces
Variants

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

From cppreference.net
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> 的公共成员函数)