在自定义库中,我看到了一个实现:
inline int is_upper_alpha(char chValue)
{
if (((chValue >= 'A') && (chValue <= 'I')) ||
((chValue >= 'J') && (chValue <= 'R')) ||
((chValue >= 'S') && (chValue <= 'Z')))
return 1;
return 0;
}
这是Easter egg或与标准C / C方法相比有哪些优势?
inline int is_upper_alpha(char chValue)
{
return ((chValue >= 'A') && (chValue <= 'Z'));
}
2 回答
这段代码的作者可能在某些时候必须支持EBCDIC,其中字母的数值是非连续的(
I
,J
和R
,S
之间存在间隙,正如您可能已经猜到的那样) .值得注意的是,C和C标准仅保证字符
0
到9
具有连续的数值,正是由于这个原因,因此这些方法都不是严格符合标准的 .看起来它试图涵盖EBCDIC和ASCII . 您的替代方法不适用于EBCDIC(它有误报,但没有误报)
C和C确实要求
'0'-'9'
是连续的 .请注意,标准库调用确实知道它们是在ASCII,EBCDIC还是其他系统上运行,因此它们更便于携带并且可能更高效 .