常见编码及转换

1、BCD码

(1)压缩BCD:4位二进制数表示一个十进制数,例如:

           0001 0010 --> 12  

           0001 0011 --> 13

(2)BCD:8位二进制数表示一个十进制数,高四位为0;

           0000 0001 0000 0010 --> 12 

           0000 0001 0000 0011 --> 13

      一般地,压缩BCD码比较常用,可以节约存储空间。

2、Hex

    Hex就是16进制,本质上是将字节数组转化为16进制,然后用字符串的形式表现出来。

    原理:一个8bit的数据,也就是(xxxx xxxx),每4个bit可以转化为一个16进制表示,也就是8个bit会转化为(00-ff)之间的16进制数字。

    hex编码 :指将数据编码16进制字符串;hex解码:指16进制字符串解码为数据。

3、Ascii

    ASCII码使用一个字节编码,所以它的范围基本是只有英文字母、数字和一些特殊符号 ,一个字节能表示的最大的整数就是255,所以,只有256个字符。

十进制 Ascii 二进制 HexString
0 48 00110000 30
1 49 00110001 31
2 50 00110010 32

4、Unicode能够表示全世界所有的字节,最常用的是用两个字节表示一个字符(如果要用到非常偏僻的字符,就需要4个字节)。

字母A用ASCII编码是十进制的65,二进制的 01000001;

字符0用ASCII编码是十进制的48,二进制的 00110000,
注意字符'0'和整数0是不同的;

汉字中已经超出了ASCII编码的范围,用Unicode编码是十进制的20013,
二进制的 01001110 00101101。

可以猜测,如果把ASCII编码的A用Unicode编码,只需要在前面补0就可以,
因此,A的Unicode编码是00000000 01000001。

5、GBK是只用来编码汉字的,GBK全称《汉字内码扩展规范》,使用双字节编码。

6、UTF-8(8-bit Unicode Transformation Format)是一种针对Unicode的可变长度字符编码,又称万国码。

   UTF-8用1到6个字节编码UNICODE字符。
   用在网页上可以同一页面显示中文简体繁体及其它语言(如英文,日文,韩文)。

字符 ASCII Unicode UTF-8
A 01000001 00000000 01000001 01000001
中 x 01001110 00101101 11100100 10111000 10101101

   从上面的表格还可以发现,UTF-8编码有一个额外的好处,就是ASCII编码实际上可以被看成是UTF-8编码的一部分,所以,大量只支持ASCII编码的历史遗留软件可以在UTF-8编码下继续工作。

编码转换:
https://tool.chinaz.com/Tools/Unicode.aspx

进制转换:
https://tool.lu/hexconvert

————————————————
版权声明:本文为CSDN博主「tfygg」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/tfygg/article/details/54728415

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux是一种开源的操作系统,广泛应用于服务器、嵌入式系统和个人电脑等领域,是程序员、系统管理员和开源爱好者的首选系统之一。在Linux系统中,常常需要进行编码格式转换,以保证不同字符集的数据可以正常显示和处理。 编码格式是指将字符转换为数字二进制值的规则。不同的编码格式有不同的规则,例如ASCII编码、UTF-8编码、GB2312编码等。在Linux系统中,常常需要将一个编码格式的文件转换成另一种编码格式,以便于不同平台之间的交互和操作。 在Linux系统中,可以使用iconv命令进行编码格式转换。iconv命令支持将一个文件从一种编码格式转换成另一种编码格式,如UTF-8转GB2312、GB2312转UTF-8等。iconv命令的语法如下: iconv -f 输入编码 -t 输出编码 输入文件 > 输出文件 其中,输入编码指的是输入文件的编码格式,输出编码指的是输出文件的编码格式,输入文件指的是需要转换的文件,输出文件指的是转换后的文件保存的路径。 例如,将一个UTF-8编码的文件test.txt转换为GB2312编码,命令如下: iconv -f UTF-8 -t GB2312 test.txt > test_gb2312.txt 执行这个命令后,就可以将test.txt文件的编码格式转换为GB2312,并保存为test_gb2312.txt文件,以便在GB2312编码的操作系统中正常显示和操作。 总之,在Linux系统中,编码格式转换是一个常见的操作,可以使用iconv命令进行转换,以保证不同编码格式的文件在各种系统和平台之间的互通。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值