关于字符编码:为什么在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,把它们分别转换成二进制,如下所示:
    位数: 7 6 5 4 3 2 1 0
     E :  0 1 0 0 0 1 0 1
     e :  0 1 1 0 0 1 0 1 
    这两个ASCII码唯一不同之处就在第五位,大写字母字符的第五位永远是零,而小写字母字符的第五位永远是一,将(e-E)后的结果为:0010000,即为32.

 

 
(用文章的说法是从右往左,有第零位)

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

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

 

posted on 2015-08-13 15:20  _Ljj  阅读(2500)  评论(0编辑  收藏  举报