今天看字符编码,在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了,太远也不好。
因此这个说法还是有点道理的。