std::basic_string<CharT,Traits,Allocator>:: find
|
size_type find
(
const
basic_string
&
str, size_type pos
=
0
)
const
;
|
(1) |
(noexcept начиная с C++11)
(constexpr начиная с C++20) |
|
size_type find
(
const
CharT
*
s, size_type pos, size_type count
)
const
;
|
(2) | (constexpr начиная с C++20) |
|
size_type find
(
const
CharT
*
s, size_type pos
=
0
)
const
;
|
(3) | (constexpr начиная с C++20) |
|
size_type find
(
CharT ch, size_type pos
=
0
)
const
;
|
(4) |
(noexcept начиная с C++11)
(constexpr начиная с C++20) |
|
template
<
class
StringViewLike
>
size_type find
(
const
StringViewLike
&
t,
|
(5) |
(начиная с C++17)
(constexpr начиная с C++20) |
Находит первую подстроку, равную заданной последовательности символов. Поиск начинается с pos , т.е. найденная подстрока не должна начинаться в позиции, предшествующей pos .
[
s
,
s
+
count
)
. Этот диапазон может содержать нулевые символы.
[
s
,
s
+
Traits
::
length
(
s
)
)
не является
допустимым диапазоном
, поведение не определено.
std:: basic_string_view < CharT, Traits >> равно true и std:: is_convertible_v < const StringViewLike & , const CharT * > равно false .
Формально, подстрока str считается найденной на позиции xpos если все следующие условия true :
- xpos >= pos
- xpos + str. size ( ) <= size ( )
- для всех позиций n в str , Traits :: eq ( at ( xpos + n ) , str. at ( n ) ) .
В частности, это означает, что
- подстрока может быть найдена только если pos <= size ( ) - str. size ( )
- пустая подстрока находится на позиции pos тогда и только тогда, когда pos <= size ( )
- для непустой подстроки, если pos >= size ( ) , функция всегда возвращает npos .
Содержание |
Параметры
| str | - | строка для поиска |
| pos | - | позиция, с которой начинать поиск |
| count | - | длина подстроки для поиска |
| s | - | указатель на строку символов для поиска |
| ch | - | символ для поиска |
| t | - | объект (преобразуемый в std::basic_string_view ) для поиска |
Возвращаемое значение
Позиция первого символа найденной подстроки или npos если такая подстрока не найдена.
Исключения
Если по какой-либо причине возникает исключение, эта функция не оказывает никакого эффекта ( strong exception safety guarantee ).
Пример
#include <iomanip> #include <iostream> #include <string> void print(int id, std::string::size_type n, std::string const& s) { std::cout << id << ") "; if (std::string::npos == n) std::cout << "not found! n == npos\n"; else std::cout << "found @ n = " << n << ", substr(" << n << ") = " << std::quoted(s.substr(n)) << '\n'; } int main() { std::string::size_type n; std::string const s = "This is a string"; /* ^ ^ ^ 1 2 3 */ // поиск с начала строки n = s.find("is"); print(1, n, s); // поиск с позиции 5 n = s.find("is", 5); print(2, n, s); // поиск одиночного символа n = s.find('a'); print(3, n, s); // поиск одиночного символа n = s.find('q'); print(4, n, s); }
Вывод:
1) found @ n = 2, substr(2) = "is is a string" 2) found @ n = 5, substr(5) = "is a string" 3) found @ n = 8, substr(8) = "a string" 4) not found! n == npos
Отчеты о дефектах
Следующие отчеты о дефектах, изменяющих поведение, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Применяется к | Поведение в опубликованной версии | Корректное поведение |
|---|---|---|---|
| LWG 847 | C++98 | не было гарантии безопасности исключений | добавлена строгая гарантия безопасности исключений |
| LWG 2064 | C++11 | перегрузки (3,4) были noexcept | удалены |
| LWG 2946 | C++17 | перегрузка (5) вызывала неоднозначность в некоторых случаях | устранено путем преобразования в шаблон |
| P1148R0 |
C++11
C++17 |
noexcept для перегрузок
(4,5)
были
случайно удалены LWG2064/LWG2946 |
восстановлены |
Смотрите также
|
находит первое вхождение подстроки символов
(функция) |
|
|
находит первое вхождение широкой строки в другой широкой строке
(функция) |
|
|
находит первое вхождение символа
(функция) |
|
|
находит первое вхождение широкого символа в широкой строке
(функция) |
|
|
находит последнее вхождение подстроки
(публичная функция-член) |
|
|
находит первое вхождение символов
(публичная функция-член) |
|
|
находит первое отсутствие символов
(публичная функция-член) |
|
|
находит последнее вхождение символов
(публичная функция-член) |
|
|
находит последнее отсутствие символов
(публичная функция-член) |
|
|
находит символы в представлении
(публичная функция-член
std::basic_string_view<CharT,Traits>
)
|
|
|
ищет первое вхождение диапазона элементов
(шаблон функции) |