二进制、字节、int范围、编码

二进制

二进制,是计算技术中广泛采用的一种数制,由德国数理哲学大师莱布尼茨于1679年发明。二进制数据是用0和1两个数码来表示的数。它的基数为2,进位规则是“逢二进一”,借位规则是“借一当二”。当前的计算机系统使用的基本上是二进制系统,数据在计算机中主要是以补码的形式存储的。计算机中的二进制则是一个非常微小的开关,用“开”来表示1,“关”来表示0。
二进制的特性其实跟我们平常使用的十进制一样是一种数制。十进制是逢十进一,二进制是逢二进一。二进制比计算机出现得还早,二进制的只有0和1的特性刚好与电子的开关对应,于是二进制这种数制,就成为了计算机的根基。
参考资料:
https://baike.baidu.com/item/二进制/361457?fr=aladdin

位与字节(bit and byte)

每个0或1就是一个位(bit)。

字节是计算机信息技术用于计量储存容量的一种计量方式(和长度单位一样),作为一个单位来处理的一个二进制数字串,是构成信息的一个小单位。最常用的字节是八位的字节,即它包含八位的二进制数。

二进制部署hurbor仓库 二进制领域配置要求_python

int范围

由使用的字节数,限定的。
python2  32位  python3 超过32位后自动扩展(理论上无限)

编码

二进制部署hurbor仓库 二进制领域配置要求_ico_02


因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理。最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所以,一个字节能表示的最大的整数就是255(二进制11111111=十进制255),如果要表示更大的整数,就必须用更多的字节。比如两个字节可以表示的最大整数是65535,4个字节可以表示的最大整数是4294967295。(43亿)   

由于计算机是美国人发明的,因此,最早只有127个字符被编码到计算机里,也就是大小写英文字母、数字和一些符号,这个编码表被称为ASCII编码,比如大写字母A的编码是65,小写字母z的编码是122

但是要处理中文显然一个字节是不够的,至少需要两个字节,而且还不能和ASCII编码冲突,所以,中国制定了GB2312编码,用来把中文编进去。

你可以想得到的是,全世界有上百种语言,日本把日文编到Shift_JIS里,韩国把韩文编到Euc-kr里,各国有各国的标准,就会不可避免地出现冲突,结果就是,在多语言混合的文本中,显示出来会有乱码。

因此,Unicode应运而生。Unicode把所有语言都统一到一套编码里,这样就不会再有乱码问题了。

gbk 和 utf-8 是经常使用的编码。