std::ctype <char> :: scan_not
|
Определено в заголовке
<locale>
|
||
|
const
char
*
scan_not
(
mask m,
const
char
*
beg,
const
char
*
end
)
const
;
|
||
Находит первый символ в массиве символов
[
beg
,
end
)
который не удовлетворяет классификационной маске
m
, то есть первый символ
c
для которого
table
(
)
[
(
unsigned
char
)
c
]
&
m
вернет
false
.
Если ( unsigned char ) c >= std:: ctype < char > :: table_size , то вместо table ( ) [ ( unsigned char ) c ] подставляется определяемое реализацией значение, возможно различное для разных значений c .
Содержание |
Параметры
| m | - | маска для поиска |
| beg | - | указатель на первый символ в массиве символов для поиска |
| end | - | указатель на позицию за последним символом массива символов для поиска |
Возвращаемое значение
Указатель на первый символ в
[
beg
,
end
)
не удовлетворяющий маске, или
end
если такой символ не был найден.
Примечания
В отличие от основного шаблона std:: ctype , эта специализация не выполняет виртуальный вызов функции при классификации символов. Для настройки поведения производный класс может предоставить нестандартную таблицу классификации в конструктор базового класса.
Пример
#include <iostream> #include <iterator> #include <locale> int main() { auto& f = std::use_facet<std::ctype<char>>(std::locale()); // пропустить начальные пробельные символы char s1[] = " \t\t\n Test"; const char* p1 = f.scan_not(std::ctype_base::space, std::begin(s1), std::end(s1)); std::cout << '\'' << p1 << "'\n"; // пропустить начальные цифры char s2[] = "123456789abcd"; const char* p2 = f.scan_not(std::ctype_base::digit, std::begin(s2), std::end(s2)); std::cout << '\'' << p2 << "'\n"; }
Вывод:
'Test' 'abcd'
Смотрите также
|
[virtual]
|
находит первый символ в последовательности, который не соответствует заданной классификации
(виртуальная защищённая функция-член
std::ctype<CharT>
)
|
|
находит первый символ в последовательности, который соответствует заданной классификации, используя таблицу классификации
(публичная функция-член) |