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