Namespaces
Variants

std::basic_string<CharT,Traits,Allocator>:: find

From cppreference.net
std::basic_string
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,

size_type pos = 0 ) const noexcept ( /* см. ниже */ ) ;
(5) (начиная с C++17)
(constexpr начиная с C++20)

Находит первую подстроку, равную заданной последовательности символов. Поиск начинается с pos , т.е. найденная подстрока не должна начинаться в позиции, предшествующей pos .

1) Находит первую подстроку, равную str .
2) Находит первую подстроку, равную диапазону [ s , s + count ) . Этот диапазон может содержать нулевые символы.
Если [ s , s + count ) не является допустимым диапазоном , поведение не определено.
3) Находит первую подстроку, равную строке символов, на которую указывает s . Длина строки определяется по первому нулевому символу с помощью Traits :: length ( s ) .
Если [ s , s + Traits :: length ( s ) ) не является допустимым диапазоном , поведение не определено.
4) Находит первый символ ch (рассматриваемый как односимвольная подстрока согласно формальным правилам ниже).
5) Неявно преобразует t в строковое представление sv как если бы std:: basic_string_view < CharT, Traits > sv = t ; , затем находит первую подстроку, равную sv .
Эта перегрузка участвует в разрешении перегрузки только если std:: is_convertible_v < const StringViewLike & ,
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 если такая подстрока не найдена.

Исключения

1,4) Ничего не выбрасывает.
5)
noexcept спецификация:
noexcept ( std:: is_nothrow_convertible_v < const T & , std:: basic_string_view < CharT, Traits >> )

Если по какой-либо причине возникает исключение, эта функция не оказывает никакого эффекта ( 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> )
ищет первое вхождение диапазона элементов
(шаблон функции)