为什么在此 C 代码中将字母表拆分为多个范围?
Why is the alphabet split into multiple ranges in this C code?
在一个自定义库中,我看到了一个实现:
inline int is_upper_alpha(char chValue)
{
if (((chValue >= 'A') && (chValue <= 'I')) ||
((chValue >= 'J') && (chValue <= 'R')) ||
((chValue >= 'S') && (chValue <= 'Z')))
return 1;
return 0;
}
这是一个复活节彩蛋还是与标准C/C++方法相比有什么优势?
inline int is_upper_alpha(char chValue)
{
return ((chValue >= 'A') && (chValue <= 'Z'));
}
这段代码的作者可能不得不在某个时候支持EBCDIC,其中字母的数值是不连续的(I
,J
和R
之间存在间隙,S
,你可能已经猜到了)。
值得注意的是,正是由于这个原因,C 和 C++ 标准仅保证0
9
字符具有连续的数值,因此这两种方法都不符合严格标准。
看起来它试图同时涵盖EBCDIC和ASCII。您的替代方法不适用于EBCDIC(它有误报,但没有假阴性)
C 和 C++确实要求'0'-'9'
是连续的。
请注意,标准库调用确实知道它们是在 ASCII、EBCDIC 还是其他系统上运行,因此它们更具可移植性,可能更高效。
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- 尝试通过多个向量访问变量时,向量下标超出范围
- 错误:未在此范围内声明'reverse'
- 正在将指针转换为范围
- 使用std::transform将一个范围的元素添加到另一个范围中
- 在基于范围的for循环中使用结构化绑定声明
- C++将向量的向量拆分为向量的N个子向量
- 如何计算数据类型的范围,例如int
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 在C++中查找范围的长度
- 如何设置一个范围来提取我想要获得的信息
- 并行用于C++17中数组索引范围内的循环
- 为左值和右值的包装器实现C++范围
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 关于:C++中异常对象的范围:为什么我没有得到副本?
- 超出范围时使用对象
- 使用范围拆分string_view
- 如何将标准::字符串拆分为标准::string_views的范围 (v3)
- 为什么在此 C 代码中将字母表拆分为多个范围?
- 循环范围拆分中的变量预评估