Пространства имён
Варианты
Действия

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

Материал из cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
Функции-элементы
Доступ к элементам
Итераторы
Ёмкость
Операции
Поиск
Константы
basic_string::npos
Правила вывода (C++17)
Функции, не являющиеся элементами
Ввод/Вывод
Сравнение
(до C++20)(до C++20)(до C++20)(до C++20)(до C++20)(C++20)
Числовые преобразования
(C++11)(C++11)(C++11)
(C++11)(C++11)
(C++11)(C++11)(C++11)
(C++11)
(C++11)
Вспомогательные классы
 
static const size_type npos = -1;

Это специальное значение, равное максимальному значению, представленному типом size_type. Точное значение зависит от контекста, но обычно оно используется либо как индикатор конца строки функциями, которые ожидают строковый индекс, либо как индикатор ошибки функциями, которые возвращают строковый индекс.

[править] Примечание

Хотя в определении используется -1, size_type это целочисленный тип без знака, а значение npos это наибольшее положительное значение, которое оно может содержать, из-за неявного преобразования знакового в беззнаковое. Это переносимый способ указать наибольшее значение любого беззнакового типа.

[править] Пример

#include <bitset>
#include <iostream>
#include <string>
 
int main()
{
    // функции поиска строк возвращают npos, если ничего не найдено
    std::string s = "test";
    if (s.find('a') == std::string::npos)
        std::cout << "нет 'a' в 'test'\n";
 
    // функции, которые принимают подмножества строк в качестве
    // аргументов, используют npos как индикатор "всё до конца"
    std::string s2(s, 2, std::string::npos);
    std::cout << s2 << '\n';
 
    std::bitset<5> b("aaabb", std::string::npos, 'a', 'b');
    std::cout << b << '\n';
}

Вывод:

нет 'a' в 'test'
st
00011

[править] Смотрите также

[static] (C++17)
особое значение. Точное значение зависит от контекста
(public static константа-элемент std::basic_string_view<CharT,Traits>) [править]