std:: isxdigit
|
定义于头文件
<cctype>
|
||
|
int
isxdigit
(
int
ch
)
;
|
||
检查给定字符是否为十六进制数字字符(
0123456789ABCDEFabcdef
)。
如果 ch 的值无法表示为 unsigned char 且不等于 EOF ,则行为未定义。
目录 |
参数
| ch | - | 待分类的字符 |
返回值
若字符为十六进制数字字符则返回非零值,否则返回零。
注释
std::isdigit
和
std::isxdigit
是唯二不受当前安装的 C 区域设置影响的标准窄字符分类函数。尽管某些实现(例如 1252 代码页中的微软实现)可能将其他单字节字符归类为数字。
与
<cctype>
中的所有其他函数一样,如果参数值既不能表示为
unsigned
char
也不等于
EOF
,则
std::isxdigit
的行为是未定义的。要安全地将这些函数用于普通
char
(或
signed
char
),应首先将参数转换为
unsigned
char
:
bool my_isxdigit(char ch) { return std::isxdigit(static_cast<unsigned char>(ch)); }
同样地,当迭代器的值类型为 char 或 signed char 时,不应直接将其与标准算法一起使用。而应先将值转换为 unsigned char :
int count_xdigits(const std::string& s) { return std::count_if(s.begin(), s.end(), // static_cast<int(*)(int)>(std::isxdigit) // 错误 // [](int c){ return std::isxdigit(c); } // 错误 // [](char c){ return std::isxdigit(c); } // 错误 [](unsigned char c){ return std::isxdigit(c); } // 正确 ); }
示例
输出:
0123456789ABCDEFabcdef
参见
|
检查字符是否被本地环境分类为十六进制数字
(函数模板) |
|
|
检查宽字符是否为十六进制字符
(函数) |
|
|
C 文档
for
isxdigit
|
|
| ASCII 值 | 字符 |
isxdigit
|
|||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 十进制 | 十六进制 | 八进制 | |||||||||||||
| 0–8 |
\x0
–
\x8
|
\0
–
\10
|
控制码 (
NUL
等)
|
≠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
|
|
| 10–13 |
\xA
–
\xD
|
\12
–
\15
|
空白字符 (
\n
,
\v
,
\f
,
\r
)
|
≠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
|
|
| 32 |
\x20
|
\40
|
空格 |
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
|
<td class="
||||