Namespaces
Variants

std::ctype<CharT>:: scan_not, std::ctype<CharT>:: do_scan_not

From cppreference.net
Определено в заголовке <locale>
public :
const CharT * scan_not ( mask m, const CharT * beg, const CharT * end ) const ;
(1)
protected :
virtual const CharT * do_scan_not ( mask m, const CharT * beg, const CharT * end ) const ;
(2)
1) Открытая функция-член, вызывает защищённую виртуальную функцию-член do_scan_not самого производного класса.
2) Находит первый символ в массиве символов [ beg , end ) который не удовлетворяет классификационной маске m , то есть первый символ c для которого is ( m, c ) вернет false .

Содержание

Параметры

m - маска для поиска
beg - указатель на первый символ в массиве символов для поиска
end - указатель на позицию за последним символом массива символов для поиска

Возвращаемое значение

Указатель на первый символ в [ beg , end ) не удовлетворяющий маске, или end если такой символ не был найден.

Пример

#include <clocale>
#include <iostream>
#include <iterator>
#include <locale>
int main()
{
    std::setlocale(LC_ALL, "en_US.utf8");
    std::wcout.imbue(std::locale("en_US.utf8"));
    auto& f = std::use_facet<std::ctype<wchar_t>>(std::wcout.getloc());
    // пропустить ведущие пробельные символы
    wchar_t s1[] = L"      \t\t\n  Кошка";
    const wchar_t* p1 = f.scan_not(std::ctype_base::space, std::begin(s1), std::end(s1));
    std::wcout << '\'' << p1 << "'\n";
    // пропустить ведущие цифры
    wchar_t s2[] = L"123456789ネプネプ";
    const wchar_t* p2 = f.scan_not(std::ctype_base::digit, std::begin(s2), std::end(s2));
    std::wcout << '\'' << p2 << "'\n";
}

Вывод:

'Кошка'
'ネプネプ'

Смотрите также

находит первый символ в последовательности, который не соответствует заданной классификации, используя таблицу классификации
(публичная функция-член std::ctype <char> )
[virtual]
находит первый символ в последовательности, который соответствует заданной классификации
(виртуальная защищенная функция-член)