豆葵文件编码批量转换工具(豆葵GB/BIG5/UTF-8转换器)是一个将GB/BIG5/UTF-8等编码相互转换的工具。开云
最近要把原先的GB编码的java工程转化为UTF-8编码,如果一个个转换,不知道要转到什么时候。还好找了个【GB/BIG5/UTF-8文件编码批量转换程序】,一次性完成转换,爽啊
1、字符编码、内码,顺带介绍汉字编码
字符必须编码后才能被计算机处理。计算机使用的缺省编码方式就是计算机的内码。早期的计算机使用7位的ASCII编码,为了处理汉字,程序员设计了用于简体中文的GB2312和用于繁体中文的big5。
GB2312(1980年)一共收录了7445个字符,包括6763个汉字和682个其它符号。汉字区的内码范围高字节从B0-F7,低字节从A1-FE,占用的码位是72*94=6768。其中有5个空位是D7FA-D7FE。
GB2312支持的汉字太少。1995年的汉字扩展规范GBK1.0收录了21886个符号,它分为汉字区和图形符号区。汉字区包括21003个字符。2000年的GB18030是取代GBK1.0的正式国家标准。该标准收录了27484个汉字,同时还收录了藏文、蒙文、维吾尔文等主要的少数民族文字。现在的PC平台必须支持GB18030,对嵌入式产品暂不作要求。所以手机、MP3一般只支持GB2312。
从ASCII、GB2312、GBK到GB18030,这些编码方法是向下兼容的,即同一个字符在这些方案中总是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文可以统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB2312、GBK到GB18030都属于双字节字符集(DBCS)。
有的中文Windows的缺省内码还是GBK,可以通过GB18030升级包升级到GB18030。不过GB18030相对GBK增加的字符,普通人是很难用到的,通常我们还是用GBK指代中文Windows内码。
这里还有一些细节:
GB2312的原文还是区位码,从区位码到内码,需要在高字节和低字节上分别加上A0。
在DBCS中,GB内码的存储格式始终是bigendian,即高位在前。
GB2312的两个字节的最高位都是1。但符合这个条件的码位只有128*128=16384个。所以GBK和GB18030的低字节最高位都可能不是1。不过这不影响DBCS字符流的解析:在读取DBCS字符流时,只要遇到高位为1的字节,就可以将下两个字节作为一个双字节编码,而不用管低字节的高位是什么。
2、Unicode、UCS和UTF
前面提到从ASCII、GB2312、GBK到GB18030的编码方法是向下兼容的。而Unicode只与ASCII兼容(更准确地说,是与ISO-8859-1兼容),与GB码不兼容。例如“汉”字的Unicode编码是6C49,而GB码是BABA。
Unicode也是一种字符编码方法,不过它是由国际组织设计,可以容纳全世界所有语言文字的编码方案。Unicode的学名是"UniversalMultiple-OctetCodedCharacterSet",简称为UCS。UCS可以看作是"UnicodeCharacterSet"的缩写。
根据维基百科全书(http://zh.wikipedia.org/wiki/)的记载:历史上存在两个试图独立设计Unicode的组织,即国际标准化组织(ISO)和一个软件制造商的协会(unicode.org)。ISO开发了ISO10646项目,Unicode协会开发了Unicode项目。
在1991年前后,双方都认识到世界不需要两个不兼容的字符集。于是它们开始合并双方的工作成果,并为创立一个单一编码表而协同工作。从Unicode2.0开始,Unicode项目采用了与ISO10646-1相同的字库和字码。
目前两个项目仍都存在,并独立地公布各自的标准。Unicode协会现在的最新版本是2005年的Unicode4.1.0。ISO的最新标准是10646-3:2003。
UCS规定了怎么用多个字节表示各种文字。怎样传输这些编码,是由UTF(UCSTransformationFormat)规范规定的,常见的UTF规范包括UTF-8、UTF-7、UTF-16。
IETF的RFC2781和RFC3629以RFC的一贯风格,清晰、明快又不失严谨地描述了UTF-16和UTF-8的编码方法。我总是记不得IETF是InternetEngineeringTaskForce的缩写。但IETF负责维护的RFC是Internet上一切规范的基础。
3、UCS-2、UCS-4、BMP
UCS有两种格式:UCS-2和UCS-4。顾名思义,UCS-2就是用两个字节编码,UCS-4就是用4个字节(实际上只用了31位,最高位必须为0)编码。下面让我们做一些简单的数学游戏:
UCS-2有2^16=65536个码位,UCS-4有2^31=2147483648个码位。
UCS-4根据最高位为0的最高字节分成2^7=128个group。每个group再根据次高字节分为256个plane。每个plane根据第3个字节分为256行(rows),每行包含256个cells。当然同一行的cells只是最后一个字节不同,其余都相同。
group0的plane0被称作BasicMultilingualPlane,即BMP。或者说UCS-4中,高两个字节为0的码位被称作BMP。
将UCS-4的BMP去掉前面的两个零字节就得到了UCS-2。在UCS-2的两个字节前加上两个零字节,就得到了UCS-4的BMP。而目前的UCS-4规范中还没有任何字符被分配在BMP之外。
4、UTF编码
UTF-8就是以8位为单元对UCS进行编码。从UCS-2到UTF-8的编码方式如下:
UCS-2编码(16进制)UTF-8字节流(二进制)
0000-007F0xxxxxxx
0080-07FF110xxxxx10xxxxxx
0800-FFFF1110xxxx10xxxxxx10xxxxxx
例如“汉”字的Unicode编码是6C49。6C49在0800-FFFF之间,所以肯定要用3字节模板了:1110xxxx10xxxxxx10xxxxxx。将6C49写成二进制是:0110110001001001,用这个比特流依次代替模板中的x,得到:111001101011000110001001,即E6B189。
读者可以用记事本测试一下我们的编码是否正确。
UTF-16以16位为单元对UCS进行编码。对于小于0x10000的UCS码,UTF-16编码就等于UCS码对应的16位无符号整数。对于不小于0x10000的UCS码,定义了一个算法。不过由于实际使用的UCS2,或者UCS4的BMP必然小于0x10000,所以就目前而言,可以认为UTF-16和UCS-2基本相同。但UCS-2只是一个编码方案,UTF-16却要用于实际的传输,所以就不得不考虑字节序的问题。
5、UTF的字节序和BOM
UTF-8以字节为编码单元,没有字节序的问题。UTF-16以两个字节为编码单元,在解释一个UTF-16文本前,首先要弄清楚每个编码单元的字节序。例如收到一个“奎”的Unicode编码是594E,“乙”的Unicode编码是4E59。如果我们收到UTF-16字节流“594E”,那么这是“奎”还是“乙”?
Unicode规范中推荐的标记字节顺序的方法是BOM。BOM不是“BillOfMaterial”的BOM表,而是ByteOrderMark。BOM是一个有点小聪明的想法:
在UCS编码中有一个叫做"ZEROWIDTHNO-BREAKSPACE"的字符,它的编码是FEFF。而FFFE在UCS中是不存在的字符,所以不应该出现在实际传输中。UCS规范建议我们在传输字节流前,先传输字符"ZEROWIDTHNO-BREAKSPACE"。
这样如果接收者收到FEFF,就表明这个字节流是Big-Endian的;如果收到FFFE,就表明这个字节流是Little-Endian的。因此字符"ZEROWIDTHNO-BREAKSPACE"又被称作BOM。
UTF-8不需要BOM来表明字节顺序,但可以用BOM来表明编码方式。字符"ZEROWIDTHNO-BREAKSPACE"的UTF-8编码是EFBBBF(读者可以用我们前面介绍的编码方法验证一下)。所以如果接收者收到以EFBBBF开头的字节流,就知道这是UTF-8编码了。
Windows就是使用BOM来标记文本文件的编码方式的。
展开内容
7.7/768.9M
茂域智能app是一款专为智能照明设备设计的手机控制平台,它可以让用户轻松地通过手机来控制家中的照明设备。该应用程序具有直观的用户界面,使用户可以方便地控制设备的...
7.9/315.3M
zblog火车头采集器发布模块插件,一款超级棒的PHP程序软件的插件哦!用起来十分的方便,让你轻轻松松地进行使用哦!欢迎前来东坡下载体验哦!zblog火车头采集...
9.0/1,823.9M
绝地枪王0.1折无限充无限打金永久0.1折,上线还有十万红包和百亿仙玉免费领,bgm响起来的时候还挺有感觉的,这游戏建模没的说,跟想象中仙侠游戏的样子差不多,就...
10.0/1,652.8M
NoActive框架是一个Xposed模块框架,这个是安卓最新版本,这款软件功能还是很强大的,可以帮助你冻结后台内存的应用,不要让它做任何事情,也不会耗流量,提...
7.6/540.2M
救救孩子ThinkoftheChildren是一款模拟类游戏,也叫照顾熊孩子游戏,玩家又当爹又当妈的家长培(quàn)训(tuì)模拟游戏,小孩非常大的调皮,需...
9.1/1,304.3M
疯狂文字,抖音爆款文字解谜小游戏,融合文字解谜,西游剧情等元素,几十个文字关卡开启,脑洞大开一起解谜闯关,随时都可以在游戏之中进行闯关,让每一个玩家都可以体验最...
8.8/1,767.8M
delphixe2软件拥有一个可视化的集成开发环境(IDE),采用面向对象的编程语言ObjectPascal和基于部件的开发结构框架。Delphi它提供了500...
9.1/1,753.8M
现在许多玩家在游戏的时候都想要陪练,闲来鱼丸app就能满足你的需要,它是一款专业的游戏约玩平台,这里你能找到志同道合的朋友,聊游戏、聊人生都不是问题,还有游戏大...
8.6/1,046.1M
迷你DAYZ黑屏修复版是一款非常好玩的生存游戏,玩家要在这个充满危险的世界生存到最后,东坡为您带来了迷你DAYZ黑屏修复版,欢迎下载体验!游戏简介《迷你Dayz...
9.3/1,696.1M
FANUC助手app是一款专业的数控系统移动端开发调试工具,集系统参数查询、PMC转换识别、异常报警监测等核心功能于一体,通过提供详尽的系统说明书资料库和智能化...
8.1/1,868.4M
武汉交通违章查询app是一款专为江城人民打造的机动车交通违章软件,用户通过武汉交通违章查询app能快速的查询车辆违章和最新油价,方便市民出行,有需要的话就来下载...
9.5/1,030.8M
斗兽棋达人是一款非常有趣的益智游戏,游戏以卡通Q萌的画面还原最正式的斗兽棋玩法,相信很多小伙伴小时候都玩过,游戏中还可以邀请你的小伙伴一起PK哦,感兴趣的小火熬...
8.1/1,421.7M
8BX交易平台是一款外汇原油贵金属交易软件,0元开户,是黄金白银股票投资的首选软件,为用户提供了非常优质安全的服务,简单好用,适合那些对投资黄金白银有意愿的用户...
9.4/1,161.3M
零零游戏盒子官方版,是一款有非常多种类游戏的游戏盒子,玩家只要一上线就可以领取非常多的游戏奖励,有非常多的破解软件可以免费的使用,比比人可以更早的玩破解的游戏。...
8.3/208.7M
魔城之战1.26是一款最新发布的魔兽地图,经典防守地图玩法,小编为您的爱来了最新发布的vip礼包密码及隐藏英雄密码,欢迎来下载体验!魔城之战1.26破解版介绍地...
9.4/464.8M
塑身单车app是一款最新的共享单车软件,用户可以就近扫码用车,自由还车等,更多超多优惠活动等你来骑,塑身单车-致力于做绿色出行的共享单车!有喜欢的用户赶紧下载使...
7.9/921.7M
劲乐时代是一款画风十分精致的音乐游戏,游戏中的人物立绘和画面场景都充斥着二次元美术风格,而且这里面的音乐舞曲非常的丰富,玩家可以选择自己喜欢的音乐进行挑战,随着...
8.5/1,774.7M
实况足球2018隐藏球员补丁是一款能够免费解锁在游戏中没有出现的球员,传奇球心马拉多纳可以给玩家直接使用,非常不错,喜欢的朋友们快点来下载试试吧。一款非常不错的...
7.7/600.3M
这是一份非常实用的ppt素材模板——10秒倒计时亮灯指示ppt特效模板,怎么样?还是挺炫酷的吧?如果你需要一份倒计时ppt素材模板,那么该倒计时10秒倒计时亮灯...
7.9/1,705.0M
开家汉堡店(v我50)游戏是一款玩法简单有趣的模拟经营类小游戏,只需要在屏幕上滑动点击就能管理你的汉堡店,控制小人将汉堡店里的设施进行完善,招募更多的员工来提供...
9.6/1,921.9M
这是一个新版的修仙类型游戏,可玩性高,画风精美,全新的3d动作类型风格,玩家可以在这里体验到各种高品质的战斗新玩法,国风新版本游戏。剑来遮天游戏简介一个全新上线...
9.4/1,855.3M
AI智能助理是一个基于ai人工智能技术打造的应用,可以应用的场景很多,像是生活百科小知识,智能ai写作,文章修改和续写等,还有七夕情人节等等怎么给女友或者男友表...
9.9/1,231.9M
裕达乐购app是一个进口商品手机购物平台,通过裕达乐购手机app可以随时购买各种进口商品,各种优惠不断,欢迎来下载!裕达乐购海外购物商城“裕达乐购”能给您一站式...
9.6/1,053.1M
最受欢迎的、最佳公平的休闲手游,圈地充饥(Paper.io2),类似贪吃蛇的玩法,你控制一条蛇进行冒险,躲避障碍物,占领更多的多边形面积。圈地充饥简介想知道你的...
9.1/800.7M
电池损耗检测app是一款手机电池电量检测工具,需要root的权限,需要7.0的系统,能更好更准确的检测出你电池的损耗情况,小编这附上电池损耗检测安卓下载。怎么用...