isdigit函数仅接受unsigned char或EOF,传入有符号char可能因负值导致未定义行为;它只识别ASCII '0'–'9',不支持Unicode、全角或上标数字。
unsigned char 或 EOF,传 char 可能崩溃isdigit 是 C 标准库函数(),C++ 中常通过 引入。它**不接受负值**——但 char 在某些平台默认是有符号的,比如值为 'ÿ'(ASCII 255)时,若 char 是 signed,会被解释为 -1,传给 isdigit 就触发未定义行为(常见表现:程序崩溃或返回错误结果)。
正确做法是先强制转成 unsigned char:
char c = '7'; if (std::isdigit(static_cast(c))) { /* 安全 */ }
char 变量给 isdigit
std::string 的某个字符(如 s[i])时同样要转型EOF 是合法的(返回 false),但仅在输入流检测场景中用到isdigit 只识别 '0' 到 '9' 这 10 个字节值(即 0x30–0x39),**不识别 Unicode 数字、全角数字、上标数字(如 ⁰¹²)、甚至不识别负号或小数点**。它和“这个字符能不能参与数字解析”完全无关。
isdigit('0')(全角零)→ false(UTF-8 编码是多字节,首字节不是 0x30)isdigit('5') → trueisdigit('-') → false(这不是数字字符,是符号)isdigit('a') → false如果需要支持 Unicode 数字,得用 ICU 库或 C++20 的 std::is_digit(配合 locale),但那是另一套逻辑。

如果只处理 ASCII 数字,直接写 c >= '0' && c 更轻量、无转型负担、无头文件依赖,且语义清晰:
char c = '3';
if (c >= '0' && c <= '9') { /* 安全、高效、可读 */ }cmp + jl/jg),性能不低于 isdigit
char、unsigned char、int 等整型变量C++ 标准库在 中提供了带 std::locale 参数的 std::isdigit 重载,理论上可支持 locale-aware 判断。但实际中:
"C" 和 "en_US.UTF-8")对 isdigit 的实现仍是查 ASCII 表digit 类别std::use_facet<:ctype>>(loc).is(std::ctype_base::digit, c) —— 但这也极少有人用结论:除非你在做国际化文本分析系统,并已深度集成 ICU,否则别碰这个重载版本。
最安全、最常用、最不容易翻车的方式,就是 static_cast 后再调 std::isdigit;而如果确定只跑 ASCII,c >= '0' && c 更干脆。别忽略字符的符号性,这是踩坑最多的地方。