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> )