关于字符编码:为什么在ASCII字符集中小写字母比大写字母大32

今天看字符编码,在ASCII一节,字母'A'用ASCII编码是十进制的65,自然想到了'a'应该和'A'差个26吧,却发现'a'是十进制的97,差了32。突然很想知道为什么。

查了ASCII码表,发现排在'Z'之后的是

' [ '

' \ '

' ] '

' ^ '

' _ '

‘ ` ’

而至于为什么要再大小写字母中间插入这些,使其相差32,并没有查到明确统一的说明,

不过这篇博客http://blog.sina.com.cn/s/blog_4c7d76240100081r.html有个说法:

以E和e 为例进行说明:
E对应的ASCII字符集中的十进制表示为69,而e对应的十进制数是101,把它们分别转换成二进制,如下所示:
位数:
E :
e :
这两个ASCII码唯一不同之处就在第五位,大写字母字符的第五位永远是零,而小写字母字符的第五位永远是一,将(e-E)后的结果为:,即为32.
 
(用文章的说法是从右往左,有第零位)

按此来看,确实有方便之处,再加上,2^4< 26< 2^5,只从第四位开始肯定是不够用的,从第五位开始刚好,第六位0和1的变化就差64了,太远也不好。

因此这个说法还是有点道理的。

上一篇:php:检测用户当前浏览器是否为IE浏览器


下一篇:What and where are the stack and heap?