关于单位

  1. #
  2. 数据存储的最小单位。每个二进制数字0或者1就是1个位;
  3. # 字节
  4. 8个位构成一个字节;即:1 byte (字节)= 8 bit(位);
  5. 1 KB = 1024 B(字节);
  6. 1 MB = 1024 KB; (2^10 B)
  7. 1 GB = 1024 MB; (2^20 B)
  8. 1 TB = 1024 GB; (2^30 B)
  9. # 字符
  10. aA、中、+、*、の......均表示一个字符;
  11. 一般 utf-8 编码下,一个汉字 字符 占用 3 字节;
  12. 一般 gbk 编码下,一个汉字 字符 占用 2 字节;
  13. # 字符集
  14. 即各种各个字符的集合,也就是说哪些汉字,字母(Abc)和符号(空格、引号..)会被收入标准中;

字符集编码

  1. 规定每个“字符”分别用一个字节还是多个字节存储,用哪些字节来存储,这个规定就叫做“编码”。
  2. (其实就是对字符集中字符进行编码,即:每个字符用二进制在计算中表示存储)
  3. 通俗的说:编码就是按照规则对字符进行翻译成对应的二进制数,在计算器中运行存储,用户看的时候(比如浏览器),在用对应的编码解析出来用户能看懂的;
  4. # 标准ASCii字符集
  5. 96个打印字符,和32个控制字符组成;一共96+32=128个;
  6. 7位二进制数来对每1个字符进行编码;
  7. 而由于7位还还不够1个字节,而电脑的内部常用字节来用处理,每个字节中多出来的最高位用0替代;
  8. 0 000 0000.........................0
  9. 0 111 1111..........................127 0----127,来表示128ACSii编码;
  10. 比如:字符 'A'----------在计算器内部用0100 0001 65)来表示;
  11. 字符'a'-----------在计算器内部用0 110 0001 97)来表示;
  12. 注意:'10'在计算器内部是没有编码的,因为它是字符串,而不是单个字符。可以分别对1,0字符编码存储;
  13. # 扩展ASCii字符集
  14. 将标准的ASCii最高位1,得到十进制代码128---2551 000 0000----1 111 1111);所以字符集一共有0---255, 256个字符;
  15. # gb2312字符集
  16. 所有汉字字符在计算机内部采用2个字节来表示,
  17. 每个字节的最高位规定为1【正好与标准ASCii字符(最高位是0)不重叠,并兼容】,
  18. 不支持繁体字;
  19. 所以:gb2312表示汉字的编码为:[129--255][129--255] (两个字节,每个字节最高位是1);小于127的字符,与ASCii编码相同;
  20. # gbk字符集
  21. gb2312的扩充,兼容gb2312,除了收录gb2312所有的字符外,还收录了其他不常见的汉字、繁体字等;
  22. gbk中字符是一个或两个字节,单字节字符00--7F0---127)这个区间和ASCII是一样的;
  23. 双字节字符的第一个字节是在81--FE129--254)之间。通过这个可以判断是单字节还是双字节;
  24. 即:在gbk字符编码,如果第一个字节是>128的,则再往后找一个字节,组成汉字;如果第一个字节<128,则表示的是一个单字节(此时和ASCII是一样的);
  25. # Unicode字符集
  26. 容纳世界上所有语言字符和符号的集合;(以及对应的二进制数字);
  27. Unicode只是一个编码规范,目前实际实现的unicode编码只要有三种:UTF-8,UCS-2UTF-16,三种unicode字符集之间可以按照规范进行转换。
  28. # utf-8编码
  29. UTF-88-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,也是一种前缀码。它可以用来表示Unicode标准中的任何字符,且其编码中的第一个字节仍与ASCII兼容,这使得原来处理ASCII字符的软件无须或只须做少部分修改,即可继续使用。因此,它逐渐成为电子邮件、网页及其他存储或发送文字的应用中,优先采用的编码。
  30. 对于UTF-8编码中的任意字节B,如果B的第一位为0,则B独立的表示一个字符(ASCII码);
  31. 如果B的第一位为1,第二位为0,则B为一个多字节字符中的一个字节(非ASCII字符);
  32. 如果B的前两位为1,第三位为0,则B为两个字节表示的字符中的第一个字节;
  33. 如果B的前三位为1,第四位为0,则B为三个字节表示的字符中的第一个字节;
  34. 如果B的前四位为1,第五位为0,则B为四个字节表示的字符中的第一个字节;
  35. 因此,对UTF-8编码中的任意字节,根据第一位,可判断是否为ASCII字符;根据前二位,可判断该字节是否为一个字符编码的第一个字节;根据前四位(如果前两位均为1),可确定该字节为字符编码的第一个字节,并且可判断对应的字符由几个字节表示;根据前五位(如果前四位为1),可判断编码是否有错误或数据传输过程中是否有错误。
  36. 即:
  37. 1、单字节的字符,字节的第一位设为0,对于英语文本,UTF-8码只占用一个字节,和ASCII码完全相同;
  38. 2n个字节的字符(n>1),第一字节的前n位设为1,第n+1位设为0,后面字节的前两位都设为10
  39. 32个字节,第一个字节的前2位是13个字节,第一个字节的前三位是1 4个字节,第一个字节的前4位都是1

image.png