std::isalnum
来自 cppreference.cn
在头文件 <cctype> 中定义 |
||
int isalnum( int ch ); |
||
检查给定字符是否是当前 C 语言环境中分类的字母数字字符。在默认语言环境中,以下字符是字母数字字符:
- 数字(
0123456789
) - 大写字母(
ABCDEFGHIJKLMNOPQRSTUVWXYZ
) - 小写字母(
abcdefghijklmnopqrstuvwxyz
)
如果 ch 的值不能表示为 unsigned char 且不等于 EOF,则行为未定义。
目录 |
[编辑] 参数
ch | - | 要分类的字符 |
[编辑] 返回值
如果字符是字母数字字符,则返回非零值;否则返回 0
。
[编辑] 注意
与 <cctype> 中的所有其他函数一样,如果参数的值既不能表示为 unsigned char 也不能等于 EOF,则 std::isalnum
的行为未定义。为了安全地将这些函数与普通 char(或 signed char)一起使用,参数应首先转换为 unsigned char。
bool my_isalnum(char ch) { return std::isalnum(static_cast<unsigned char>(ch)); }
同样,当迭代器值类型为 char 或 signed char 时,不应直接将它们与标准算法一起使用。相反,应首先将值转换为 unsigned char。
int count_alnums(const std::string& s) { return std::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::isalnum) // wrong // [](int c){ return std::isalnum(c); } // wrong // [](char c){ return std::isalnum(c); } // wrong [](unsigned char c){ return std::isalnum(c); } // correct ); }
[编辑] 示例
演示了在不同语言环境(操作系统相关)下使用 std::isalnum
。
运行此代码
#include <cctype> #include <clocale> #include <iostream> int main() { unsigned char c = '\xdf'; // German letter ß in ISO-8859-1 std::cout << "isalnum(\'\\xdf\', default C locale) returned " << std::boolalpha << static_cast<bool>(std::isalnum(c)) << '\n'; if (std::setlocale(LC_ALL, "de_DE.iso88591")) std::cout << "isalnum(\'\\xdf\', ISO-8859-1 locale) returned " << static_cast<bool>(std::isalnum(c)) << '\n'; }
可能的输出
isalnum('\xdf', default C locale) returned false isalnum('\xdf', ISO-8859-1 locale) returned true
[编辑] 参阅
检查字符是否被区域设置分类为字母数字 (函数模板) | |
检查宽字符是否为字母或数字 (函数) | |
C 文档 for isalnum
|
ASCII 值 | 字符 |
isalnum |
|||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
十进制 | 十六进制 | 八进制 | |||||||||||||
0–8 | \x0 –\x8 |
\0 –\10 |
控制码(NUL 等) |
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
9 | \x9
|
\11
|
制表符(\t ) |
≠0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
10–13 | \xA –\xD |
\12 –\15 |
空白符(\n 、\v 、\f 、\r ) |
≠0
|
0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
14–31 | \xE –\x1F |
\16 –\37 |
控制码 | ≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
32 | \x20
|
\40
|
空格 | 0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
33–47 | \x21 –\x2F |
\41 –\57 |
!"#$%&'()*+,-./
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
48–57 | \x30 –\x39 |
\60 –\71 |
0123456789
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
0
|
0
|
0
|
≠0
|
≠0
|
58–64 | \x3A –\x40 |
\72 –\100 |
:;<=>?@
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
65–70 | \x41 –\x46 |
\101 –\106 |
ABCDEF
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
≠0
|
71–90 | \x47 –\x5A |
\107 –\132 |
GHIJKLMNOP QRSTUVWXYZ
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
≠0
|
0
|
0
|
0
|
91–96 | \x5B –\x60 |
\133 –\140 |
[\]^_`
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
97–102 | \x61 –\x66 |
\141 –\146 |
abcdef
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
0
|
≠0
|
0
|
≠0
|
103–122 | \x67 –\x7A |
\147 –\172 |
ghijklmnop qrstuvwxyz
|
0
|
≠0
|
0
|
0
|
≠0
|
0
|
≠0
|
≠0
|
0
|
≠0
|
0
|
0
|
123–126 | \x7B –\x7E |
\172 –\176 |
{|}~
|
0
|
≠0
|
0
|
0
|
≠0
|
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
127 | \x7F
|
\177
|
退格字符(DEL ) |
≠0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|
0
|