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

std::isalnum

Материал из cppreference.com
< cpp‎ | string‎ | byte
 
 
 
Однобайтовые строки с завершающим нулём
Функции
Манипуляции с символами
Преобразование в числовые форматы
Манипуляции со строками
Проверка строки
Манипуляции с памятью
Разное
 
Определено в заголовочном файле <cctype>
int isalnum(int ch );

Проверяет, является ли данный символ буквенно-цифровым символом, классифицированным текущей локалью C. В локали по умолчанию следующие символы являются буквенно-цифровыми:

  • цифры (0123456789)
  • заглавные буквы (ABCDEFGHIJKLMNOPQRSTUVWXYZ)
  • строчные буквы (abcdefghijklmnopqrstuvwxyz)

Поведение не определено, если значение ch не может быть представлено как unsignedchar и не равно EOF.

Содержание

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

ch символ для классификации

[править]Возвращаемое значение

Ненулевое значение, если символ является буквенно-цифровым, иначе 0.

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

Как и все другие функции из <cctype>, поведение std::isalnum не определено, если значение аргумента не может быть представлено как unsignedchar и не равно EOF. Чтобы безопасно использовать эти функции с простыми char (или signedchar), аргумент сначала должен быть преобразован в unsignedchar:

bool my_isalnum(char ch){return std::isalnum(static_cast<unsignedchar>(ch));}

Также, их не следует использовать напрямую со стандартными алгоритмами, если тип значения итератора является char или signedchar. Вместо этого сначала преобразуйте значение в unsignedchar:

int count_alnums(conststd::string& s){returnstd::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::isalnum) // неправильно// [](int c){ return std::isalnum(c); } // неправильно// [](char c){ return std::isalnum(c); } // неправильно[](unsignedchar c){return std::isalnum(c);}// правильно);}

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

Демонстрирует использование std::isalnum с различными локалями (зависит от ОС).

#include <cctype>#include <clocale>#include <iostream>   int main(){unsignedchar c ='\xdf';// Немецкая буква ß в ISO-8859-1   std::cout<<"isalnum(\'\\xdf\', локаль C по умолчанию) возвращает "<<std::boolalpha<<static_cast<bool>(std::isalnum(c))<<'\n';   if(std::setlocale(LC_ALL, "de_DE.iso88591"))std::cout<<"isalnum(\'\\xdf\', локаль ISO-8859-1) возвращает "<<static_cast<bool>(std::isalnum(c))<<'\n';   }

Возможный вывод:

isalnum('\xdf', локаль C по умолчанию) возвращает false isalnum('\xdf', локаль ISO-8859-1) возвращает true

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

проверяет, классифицируется ли символ локалью как буквенно-цифровой
(шаблон функции)[править]
проверяет, является ли широкий символ буквенно-цифровым
(функция)[править]
ASCII значения символы

iscntrl
iswcntrl

isprint
iswprint

isspace
iswspace

isblank
iswblank

isgraph
iswgraph

ispunct
iswpunct

isalnum
iswalnum

isalpha
iswalpha

isupper
iswupper

islower
iswlower

isdigit
iswdigit

isxdigit
iswxdigit

деся-тичные шестнад-цатерич-ные восьме-ричные
0–8 \x0\x8\0\10 управляющие коды (NUL, и т.д.) ≠000000000000
9 \x9\11 табуляция (\t) ≠00≠0≠000000000
10–13 \xA\xD\12\15 пробельные (\n, \v, \f, \r) ≠00≠0000000000
14–31 \xE\x1F\16\37 управляющие коды ≠000000000000
32 \x20\40 пробел 0≠0≠0≠000000000
33–47 \x21\x2F\41\57!"#$%&'()*+,-./0≠000≠0≠0000000
48–57 \x30\x39\60\7101234567890≠000≠00≠0000≠0≠0
58–64 \x3A\x40\72\100:;<=>?@0≠000≠0≠0000000
65–70 \x41\x46\101\106ABCDEF0≠000≠00≠0≠0≠000≠0
71–90 \x47\x5A\107\132GHIJKLMNOP
QRSTUVWXYZ
0≠000≠00≠0≠0≠0000
91–96 \x5B\x60\133\140[\]^_`0≠000≠0≠0000000
97–102 \x61\x66\141\146abcdef0≠000≠00≠0≠00≠00≠0
103–122 \x67\x7A\147\172ghijklmnop
qrstuvwxyz
0≠000≠00≠0≠00≠000
123–126 \x7B\x7E\172\176{|}~0≠000≠0≠0000000
127 \x7F\177 символ возврата (DEL) ≠000000000000
ne:cpp/string/byte/isalnum
close