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

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)
Вспомогательные классы
 
staticconst 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>)[править]
close