1. ASCII编码:
ASCII编码是1个字节,Unicode编码通常是2个字节。
字母A用ASCII编码是十进制的65,二进制的01000001;
2. Unicode编码
因ASCII编码1个字节不够编码全部字符,所以用Unicode编码补救。
eg:如果把ASCII编码转换成=》Unicode编码,只需在前面补0。因此,A的Unicode编码是0000000001000001。
统一成Unicode编码,乱码问题消失了。但是用Unicode编码比ASCII编码需要多一倍的存储空间,会在存储和传输上造成浪费。
3. UTF-8编码
本着节约的精神:=>把Unicode编码转化为“可变长编码”的UTF-8编码。
UTF-8编码把一个Unicode字符根据不同的数字大小编码成1-6个字节,常用的英文字母被编码成1个字节,汉字通常是3个字节,生僻的字符继续编码成4-6个字节。
用UTF-8编码节省空间:
![001d5d7e18228ab3173df5a3e784266d.png](https://img-blog.csdnimg.cn/img_convert/001d5d7e18228ab3173df5a3e784266d.png)
UTF-8编码额外的好处:部分ASCII编码 = UTF-8编码。
4. 应用举例
Python3 内存中使用的字符串是 Unicode编码,但是网络传输的数据是 UTF-8 编码。
从网络中读取数据: UTF-8 编码的数据--->decode---> Unicode编码;
反之,存储数据:Unicode编码-->encode--> UTF-8 编码