GBK (Zeichensatz)

Windows-Codepages
0874Thai
0932Japanisch
0936Vereinfachtes Chinesisch
0949Koreanisch
0950Traditionelles Chinesisch
1250Mitteleuropäisch
1251Kyrillisch
1252Westeuropäisch
1253Griechisch
1254Türkisch
1255Hebräisch
1256Arabisch
1257Baltisch
1258Vietnamesisch
65001Unicode (UTF-8)

GBK (kurz für chinesisch 国家标准扩展, Pinyin Guójiā biāozhǔn kuòzhǎn; von GB Standard sowie chinesisch 汉字内码扩展规范, Pinyin Hànzì nèimǎ kuòzhǎn guīfàn, englisch Chinese Internal Code Specification) ist ein chinesischer Zeichensatz. Er erweitert GB2312 um traditionelle Schriftzeichen sowie um Schriftzeichen, die nach der Einführung von GB2312 1981 vereinfacht wurden.

Geschichte

1993 wurde Unicode 1.1 veröffentlicht, das 20.902 chinesische Schriftzeichen enthält. Die chinesische Regierung hat daraufhin GB13000.1-93 veröffentlicht, welcher identisch mit Unicode 1.1 ist. Um die Lücke zwischen diesem Standard und dem älteren GB2312 (1980) zu überbrücken, wurde auch GBK eingeführt, das GB2312 um die Zeichen aus GB13000.1-93 erweitert. Weil GBK jedoch nie zur offiziellen Norm wurde, erhielt es auch keine reguläre GB-Nummer. 1995 wurde GBK um 95 weitere Schriftzeichen erweitert.

In Windows 95 wurde GBK als Codepage 936 in unveränderter Form übernommen. Dadurch stieg die Verbreitung von GBK enorm, und GBK wurde zum De-facto-Standard. Später wurde das Eurozeichen zur Codepage 936 hinzugefügt, was die Codepage inkompatibel zu GBK machte.

In den meisten Windows-Varianten wird GBK jedoch irreführend als GB2312 bezeichnet. Erst ab Windows XP wurde zusätzlich auch die ursprüngliche Norm GB2312 unter Windows angeboten, und zwar unter der Codepage-Nummer 20936 mit der Bezeichnung "GB2312-80".

Seit 2000 ist GBK offiziell von GB 18030 abgelöst.

Aufbau

GBK ist eine variable 16-Bit-Kodierung, d. h. ein Zeichen kann entweder ein oder zwei Byte groß sein. Die Zeichen im Bereich 00hex-7Fhex sind identisch zu ASCII und bestehen aus nur einem Byte. Die Zeichen im Bereich 81hex-FEhex hingegen bestehen aus zwei Bytes.

Ein in GBK kodierter Text kann nur vorwärts durchsucht werden, da bei einem beliebigen Zeichen nicht unterschieden werden kann, ob es Anfangsbyte oder Endebyte einer Zweibyte-Kodierung ist. Zur Unterscheidung muss der Text von Anfang an untersucht werden. Diese nachteilige Eigenschaft hat GBK mit GB2312 und GB18030 und den anderen asiatischen Kodierungen SHIFT-JIS (japanisch), BIG-5 (traditionelles Chinesisch) und EUC-KR (koreanisch) gemeinsam.

Bei GB2312 kann auch ein durch Rückwärtssuche gefundenes ASCII-Zeichen (Bytewert kleiner als 128) als Ausgangspunkt für eine Vorwärtsanalyse verwendet werden, da diese Werte nicht in Zwei-Byte-Zeichen enthalten sind; bei GBK reduziert sich diese Möglichkeit auf ASCII-Zeichen im Bereich 0 bis 63, da auch Bytewerte im Bereich 64 bis 127 als End-Byte eines Zwei-Byte-Zeichens verwendet werden.

Dieses Problem vermeidet die Unicode-Transformation UTF-8. Obwohl hier auch bis zu vier Byte pro Zeichen benötigt werden, kann doch von jedem Byte eindeutig gesagt werden, ob es ein Ein-Byte-Zeichen, ein Anfangs-Byte eines Mehr-Byte-Zeichens oder ein Folge- oder End-Byte eines Mehr-Byte-Zeichens ist.

Der Zwei-Byte-Bereich ist in acht Ebenen eingeteilt:

GBK-Levels
Level1. Byte2. ByteVerfügbare CodepunkteZeichen
GB 18030GBK 1.0GB 2312
Level GBK/1A1A9A1FE846728717682
Level GBK/2B0F7A1FE676867636763
Level GBK/381A040FE außer 7F60806080
Level GBK/4AAFE40A0 außer 7F81608160
Level GBK/5A8A940A0 außer 7F192166
benutzerdefiniertAAAFA1FE564
benutzerdefiniertF8FEA1FE658
benutzerdefiniertA1A740A0 außer 7F672
insgesamt:23.94021.89721.8867.445
Code…0…1…2…3…4…5…6…7…8…9…A…B…C…D…E…F
0…NULSOHSTXETXEOTENQACKBELBSHTLFVTFFCRSOSI
1…DLEDC1DC2DC3DC4NAKSYNETBCANEMSUBESCFSGSRSUS
2…SP!"#$%&'()*+,-./
3…0123456789:;<=>?
4…ASCII oder zweites Byte einer zwei Byte langen Sequenz.
5…
6…
7…DEL
8…
9…Erstes oder zweites Byte einer zwei Byte langen Sequenz.
A…
B…
C…
D…
E…
F…
…0…1…2…3…4…5…6…7…8…9…A…B…C…D…E…F

Weblinks