其他分享
首页 > 其他分享> > 2.1.3字符和字符串

2.1.3字符和字符串

作者:互联网

字符和字符串

1.1 ASCLL码

键盘中有一些字符数字,还有在屏幕总无法打印出来的,用于控制计算机的字符,上下键,Delete等等

由于计算机硬件只能识别0101这样的二进制数,所以用一定规则映射成0101这样的二进制数

常用控制字符共128个 =7位的二进制编码=27=128

一个bit表示0和1两种,用来代表二进制位,8个bit便可以表示256种情况=28

通常计算机处理数据的时候1个字节为处理单位=8bit

image-20200823104615104

可印刷字符:32~126,其余为控制、通信字符

数字:48对应二进制为(00110000)=(0011 0000)~57(0011 1001) 0011相同,后面0000、1001刚好代表十进制数为0-9

大写字母:65对应二进制为(01000001)=(0100 0001)~90(0101 1010) 010相同,后面00001、11010代表的十进制数为0、26,范围就是0-26

小写字母:97对应二进制为(01100001)=(0110 0001)~122(0111 1010) 010相同,后面00001、11010代表的十进制数为0、26,范围就是0-26

image-20200823110459653

1.2 汉字的表示和编码

GB 2312-80:汉字+各种符号共7445个

区位码:94个区,每个区94个位置 相当于一个格子(区,位)

国标码:在区位码基础上每个区位加上20H,防止信息交换时“控制/通信字符冲突”

区位码需要在加上20H,就是32的16进制表示,因为控制编码位于0-32.为了防止计算机把识别的字符当成指令,

所以区位码都会从32开始,而不是从0开始,这时候ASCLL码表,表示汉字的范围是32-125

汉字内码:在国标码基础上每个区位+80H(80H十六进制对应10000000二进制 最高位为1 ),ASCLL码最高位为0,加上1的话,保证与ASCLL码区分,不重合。就在原来的基础上加128,这时候一个计算机判断输入的字符为一个字节<128,就说明这是一个英文字符。如果计算机读了一个字节,还有下一个字节,把这两个字节组合起来,就能对应上一个汉字

image-20200823113936824

输出:汉字字形码

image-20200823114110089

1.3 字符串

英文字符

image-20200823114647363

中文字符

image-20200823114826893

标签:字符,26,二进制,32,区位码,ASCLL,字符串,2.1
来源: https://www.cnblogs.com/cg-ww/p/14546481.html