首页 文章

为什么字母表在此C代码中分为多个范围?

提问于
浏览
162

在自定义库中,我看到了一个实现:

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 回答

  • 54

    这段代码的作者可能在某些时候必须支持EBCDIC,其中字母的数值是非连续的( IJRS 之间存在间隙,正如您可能已经猜到的那样) .

    值得注意的是,C和C标准仅保证字符 09 具有连续的数值,正是由于这个原因,因此这些方法都不是严格符合标准的 .

  • 215

    看起来它试图涵盖EBCDIC和ASCII . 您的替代方法不适用于EBCDIC(它有误报,但没有误报)

    C和C确实要求 '0'-'9' 是连续的 .

    请注意,标准库调用确实知道它们是在ASCII,EBCDIC还是其他系统上运行,因此它们更便于携带并且可能更高效 .

相关问题