六神无主为了你,七个美女不如你,八抬大轿娶了你,九颗真心掏给你,全家幸福指望你
UNICODE,GBK,UTF-8区别
最近迷上改魔兽地图,破解解压修改挺好玩的~ 有个文件头的问题,搞了半天才知原来是utf-8码...总算把这些都搞清楚了.PHPChina 开源社区门户7MnF~0r.@@)Nh
;o/G^-p],l0简单来说,unicode,gbk和大五码就是编码的值,而utf-8,uft-16之类就是这个值的表现形式.而前面那三种编码是一兼容的,同一个汉字,那三个码值是完全不一样的.如"汉"的uncode值与gbk就是不一样的,假设uncode为a040,gbk为b030,而uft-8码,就是把那个值表现的形式.utf-8码完全只针对uncode来组织的,如果GBK要转UTF-8必须先转uncode码,再转utf-8就OK了.PHPChina 开源社区门户,?5Ngh9lh5t
PHPChina 开源社区门户+F4m)oe(^B fk
详细的就见下面转的这篇文章.PHPChina 开源社区门户Y0q!{UU%v I1u
PHPChina 开源社区门户;W h:K [&S)N
谈谈Unicode编码,简要解释UCS、UTF、BMP、BOM等名词PHPChina 开源社区门户3~'z"C2hs/Tk'v}
这是一篇程序员写给程序员的趣味读物。所谓趣味是指可以比较轻松地了解一些原来不清楚的概念,增进知识,类似于打RPG游戏的升级。整理这篇文章的动机是两个问题:
4f$|;mE*].R.r K0PHPChina 开源社区门户_:b7h|M5{^CvV`7n
问题一: PHPChina 开源社区门户NkLt1J bd
使用Windows记事本的“另存为”,可以在GBK、Unicode、Unicode big endian和UTF-8这几种编码方式间相互转换。同样是txt文件,Windows是怎样识别编码方式的呢?
&k{X qC&fK1I0PHPChina 开源社区门户QOSJCQGB\t
我很早前就发现Unicode、Unicode big endian和UTF-8编码的txt文件的开头会多出几个字节,分别是FF、FE(Unicode),FE、FF(Unicode big endian),EF、BB、BF(UTF-8)。但这些标记是基于什么标准呢?
k1WF.p D0PHPChina 开源社区门户]t$hsv7o)rB l Gv1J
问题二:
1rR B$bl8^0最近在网上看到一个ConvertUTF.c,实现了UTF-32、UTF-16和UTF-8这三种编码方式的相互转换。对于Unicode(UCS2)、GBK、UTF-8这些编码方式,我原来就了解。但这个程序让我有些糊涂,想不起来UTF-16和UCS2有什么关系。
6Y0mp%^'KpK'g#D3\!x$U0查了查相关资料,总算将这些问题弄清楚了,顺带也了解了一些Unicode的细节。写成一篇文章,送给有过类似疑问的朋友。本文在写作时尽量做到通俗易懂,但要求读者知道什么是字节,什么是十六进制。PHPChina 开源社区门户.CH AD;k
+W+N(z~ j Ex4@ d{2|PE00、big endian和little endian
7D;DFP;Ym2pv0big endian和little endian是CPU处理多字节数的不同方式。例如“汉”字的Unicode编码是6C49。那么写到文件里时,究竟是将6C写在前面,还是将49写在前面?如果将6C写在前面,就是big endian。如果将49写在前面,就是little endian。PHPChina 开源社区门户9T(JQc4O-\0Va
G-AA A$SdB0“endian”这个词出自《格列佛游记》。小人国的内战就源于吃鸡蛋时是究竟从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开,由此曾发生过六次叛乱,一个皇帝送了命,另一个丢了王位。PHPChina 开源社区门户&Kd(?r~n
PHPChina 开源社区门户Bz&_Q^
我们一般将endian翻译成“字节序”,将big endian和little endian称作“大尾”和“小尾”。
I kfMf {0
t0I.g%M1T)Ks01、字符编码、内码,顺带介绍汉字编码
J:\eD'`&A0字符必须编码后才能被计算机处理。计算机使用的缺省编码方式就是计算机的内码。早期的计算机使用7位的ASCII编码,为了处理汉字,程序员设计了用于简体中文的GB2312和用于繁体中文的big5。PHPChina 开源社区门户 y$h z@9w%gR8F
/g!W$F1B Nx&cb0GB2312(1980年)一共收录了7445个字符,包括6763个汉字和682个其它符号。汉字区的内码范围高字节从B0-F7,低字节从A1-FE,占用的码位是72*94=6768。其中有5个空位是D7FA-D7FE。PHPChina 开源社区门户mKM}!}3x
PHPChina 开源社区门户~_G/H$kaI
GB2312支持的汉字太少。1995年的汉字扩展规范GBK1.0收录了21886个符号,它分为汉字区和图形符号区。汉字区包括21003个字符。PHPChina 开源社区门户|z E%wfzcl
5},wn%}4E1E*z*q,W0从ASCII、GB2312到GBK,这些编码方法是向下兼容的,即同一个字符在这些方案中总是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文可以统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB2312、GBK都属于双字节字符集 (DBCS)。PHPChina 开源社区门户%u0hU'f~2H+YoAJ
PHPChina 开源社区门户VG}L_b Dg:{G
2000年的GB18030是取代GBK1.0的正式国家标准。该标准收录了27484个汉字,同时还收录了藏文、蒙文、维吾尔文等主要的少数民族文字。从汉字字汇上说,GB18030在GB13000.1的20902个汉字的基础上增加了CJK扩展A的6582个汉字(Unicode码0x3400-0x4db5),一共收录了27484个汉字。PHPChina 开源社区门户a U4K SU0@1V }0Qg
,]1Qfq g0CJK就是中日韩的意思。Unicode为了节省码位,将中日韩三国语言中的文字统一编码。GB13000.1就是ISO/IEC 10646-1的中文版,相当于Unicode 1.1。
4O_su] K0
P z XJ d(lU'Q)e0GB18030的编码采用单字节、双字节和4字节方案。其中单字节、双字节和GBK是完全兼容的。4字节编码的码位就是收录了CJK扩展A的6582个汉字。 例如:UCS的0x3400在GB18030中的编码应该是8139EF30,UCS的0x3401在GB18030中的编码应该是8139EF31。
dOp"cw8w0PHPChina 开源社区门户0W {rC$W&bJ}_
微软提供了GB18030的升级包,但这个升级包只是提供了一套支持CJK扩展A的6582个汉字的新字体:新宋体-18030,并不改变内码。Windows 的内码仍然是GBK。
IH }#d]0
;o/G^-p],l0简单来说,unicode,gbk和大五码就是编码的值,而utf-8,uft-16之类就是这个值的表现形式.而前面那三种编码是一兼容的,同一个汉字,那三个码值是完全不一样的.如"汉"的uncode值与gbk就是不一样的,假设uncode为a040,gbk为b030,而uft-8码,就是把那个值表现的形式.utf-8码完全只针对uncode来组织的,如果GBK要转UTF-8必须先转uncode码,再转utf-8就OK了.PHPChina 开源社区门户,?5Ngh9lh5t
PHPChina 开源社区门户+F4m)oe(^B fk
详细的就见下面转的这篇文章.PHPChina 开源社区门户Y0q!{UU%v I1u
PHPChina 开源社区门户;W h:K [&S)N
谈谈Unicode编码,简要解释UCS、UTF、BMP、BOM等名词PHPChina 开源社区门户3~'z"C2hs/Tk'v}
这是一篇程序员写给程序员的趣味读物。所谓趣味是指可以比较轻松地了解一些原来不清楚的概念,增进知识,类似于打RPG游戏的升级。整理这篇文章的动机是两个问题:
4f$|;mE*].R.r K0PHPChina 开源社区门户_:b7h|M5{^CvV`7n
问题一: PHPChina 开源社区门户NkLt1J bd
使用Windows记事本的“另存为”,可以在GBK、Unicode、Unicode big endian和UTF-8这几种编码方式间相互转换。同样是txt文件,Windows是怎样识别编码方式的呢?
&k{X qC&fK1I0PHPChina 开源社区门户QOSJCQGB\t
我很早前就发现Unicode、Unicode big endian和UTF-8编码的txt文件的开头会多出几个字节,分别是FF、FE(Unicode),FE、FF(Unicode big endian),EF、BB、BF(UTF-8)。但这些标记是基于什么标准呢?
k1WF.p D0PHPChina 开源社区门户]t$hsv7o)rB l Gv1J
问题二:
1rR B$bl8^0最近在网上看到一个ConvertUTF.c,实现了UTF-32、UTF-16和UTF-8这三种编码方式的相互转换。对于Unicode(UCS2)、GBK、UTF-8这些编码方式,我原来就了解。但这个程序让我有些糊涂,想不起来UTF-16和UCS2有什么关系。
6Y0mp%^'KpK'g#D3\!x$U0查了查相关资料,总算将这些问题弄清楚了,顺带也了解了一些Unicode的细节。写成一篇文章,送给有过类似疑问的朋友。本文在写作时尽量做到通俗易懂,但要求读者知道什么是字节,什么是十六进制。PHPChina 开源社区门户.CH AD;k
+W+N(z~ j Ex4@ d{2|PE00、big endian和little endian
7D;DFP;Ym2pv0big endian和little endian是CPU处理多字节数的不同方式。例如“汉”字的Unicode编码是6C49。那么写到文件里时,究竟是将6C写在前面,还是将49写在前面?如果将6C写在前面,就是big endian。如果将49写在前面,就是little endian。PHPChina 开源社区门户9T(JQc4O-\0Va
G-AA A$SdB0“endian”这个词出自《格列佛游记》。小人国的内战就源于吃鸡蛋时是究竟从大头(Big-Endian)敲开还是从小头(Little-Endian)敲开,由此曾发生过六次叛乱,一个皇帝送了命,另一个丢了王位。PHPChina 开源社区门户&Kd(?r~n
PHPChina 开源社区门户Bz&_Q^
我们一般将endian翻译成“字节序”,将big endian和little endian称作“大尾”和“小尾”。
I kfMf {0
t0I.g%M1T)Ks01、字符编码、内码,顺带介绍汉字编码
J:\eD'`&A0字符必须编码后才能被计算机处理。计算机使用的缺省编码方式就是计算机的内码。早期的计算机使用7位的ASCII编码,为了处理汉字,程序员设计了用于简体中文的GB2312和用于繁体中文的big5。PHPChina 开源社区门户 y$h z@9w%gR8F
/g!W$F1B Nx&cb0GB2312(1980年)一共收录了7445个字符,包括6763个汉字和682个其它符号。汉字区的内码范围高字节从B0-F7,低字节从A1-FE,占用的码位是72*94=6768。其中有5个空位是D7FA-D7FE。PHPChina 开源社区门户mKM}!}3x
PHPChina 开源社区门户~_G/H$kaI
GB2312支持的汉字太少。1995年的汉字扩展规范GBK1.0收录了21886个符号,它分为汉字区和图形符号区。汉字区包括21003个字符。PHPChina 开源社区门户|z E%wfzcl
5},wn%}4E1E*z*q,W0从ASCII、GB2312到GBK,这些编码方法是向下兼容的,即同一个字符在这些方案中总是有相同的编码,后面的标准支持更多的字符。在这些编码中,英文和中文可以统一地处理。区分中文编码的方法是高字节的最高位不为0。按照程序员的称呼,GB2312、GBK都属于双字节字符集 (DBCS)。PHPChina 开源社区门户%u0hU'f~2H+YoAJ
PHPChina 开源社区门户VG}L_b Dg:{G
2000年的GB18030是取代GBK1.0的正式国家标准。该标准收录了27484个汉字,同时还收录了藏文、蒙文、维吾尔文等主要的少数民族文字。从汉字字汇上说,GB18030在GB13000.1的20902个汉字的基础上增加了CJK扩展A的6582个汉字(Unicode码0x3400-0x4db5),一共收录了27484个汉字。PHPChina 开源社区门户a U4K SU0@1V }0Qg
,]1Qfq g0CJK就是中日韩的意思。Unicode为了节省码位,将中日韩三国语言中的文字统一编码。GB13000.1就是ISO/IEC 10646-1的中文版,相当于Unicode 1.1。
4O_su] K0
P z XJ d(lU'Q)e0GB18030的编码采用单字节、双字节和4字节方案。其中单字节、双字节和GBK是完全兼容的。4字节编码的码位就是收录了CJK扩展A的6582个汉字。 例如:UCS的0x3400在GB18030中的编码应该是8139EF30,UCS的0x3401在GB18030中的编码应该是8139EF31。
dOp"cw8w0PHPChina 开源社区门户0W {rC$W&bJ}_
微软提供了GB18030的升级包,但这个升级包只是提供了一套支持CJK扩展A的6582个汉字的新字体:新宋体-18030,并不改变内码。Windows 的内码仍然是GBK。
IH }#d]0