Namespaces
Variants

std:: isxdigit

From cppreference.net
定义于头文件 <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); } // 正确
                        );
}

示例

#include <cctype>
#include <climits>
#include <iostream>
int main()
{
    for (int c = 0; UCHAR_MAX >= c; ++c)
        if (isxdigit(c))
            std::cout << static_cast<char>(c);
    std::cout << '\n';
}

输出:

0123456789ABCDEFabcdef

另请参阅

检查字符是否被本地化环境分类为十六进制数字
(函数模板)
检查宽字符是否为十六进制字符
(函数)
C 文档 关于 isxdigit
注:根据要求,仅翻译了表格中的数字范围"65–70"为"65–70"(实际无需翻译),其余所有HTML标签、属性及 标签内的C++相关术语(如\x41、\101、ABCDEF、0、≠0等)均保持原样未作翻译。
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 等) ≠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