std::basic_string<CharT,Traits,Allocator>::npos
Материал из cppreference.com
<tbody>
</tbody>
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>)
|