實現隨機生成漢字的Java代碼

gww3 9年前發布 | 5K 次閱讀 Java

一、背景知識
GB 2312-80 是中國國家標準簡體中文字符集,全稱《信息交換用漢字編碼字符集·基本集》,由中國國家標準總局發布,1981年5月1日實施。GB2312 編碼通行于中國大陸;新加坡等地也采用此編碼。中國大陸幾乎所有的中文系統和國際化的軟件都支持 GB 2312。

GB2312 標準共收錄 6763 個漢字,其中一級漢字 3755 個,二級漢字 3008 個;同時收錄了包括拉丁字母、希臘字母、日文平假名及片假名字母、俄語西里爾字母在內的 682 個字符。GB2312 的出現,基本滿足了漢字的計算機處理需要,它所收錄的漢字已經覆蓋中國大陸 99.75% 的使用頻率。對于人名、古漢語等方面出現的罕用字,GB2312 不能處理,這導致了后來 GBK 及 GB18030 漢字字符集的出現。

GB2312 中對所收漢字進行了“分區”處理,每區含有 94 個漢字/符號。這種表示方式也稱為區位碼。

01 - 09 區為特殊符號。
16 - 55 區為一級漢字,按拼音排序。
56 - 87 區為二級漢字,按部首/筆畫排序。
10 - 15 區及 88 - 94 區則未有編碼。舉例來說,“啊”字是 GB2312 之中的第一個漢字,它的區位碼就是 1601。

每個漢字及符號以兩個字節來表示。第一個字節稱為“高位字節”,第二個字節稱為“低位字節”。“高位字節”使用了 0xA1 - 0xF7(把 01 - 87 區的區號加上 0xA0),“低位字節”使用了 0xA1 - 0xFE(把 01 - 94 位的位號加上 0xA0)。 由于一級漢字從 16 區起始,漢字區的“高位字節”的范圍是 0xB0 - 0xF7,“低位字節”的范圍是 0xA1 - 0xFE,占用的碼位是 72 * 94 = 6768。其中有 5 個空位是 D7FA - D7FE。例如“啊”字在大多數程序中,會以兩個字節,0xB0(第一個字節)0xA1(第二個字節)儲存。(與區位碼對比:0xB0 = 0xA0 + 16, 0xA1 = 0xA0 + 1)。

國家標準 GB 18030-2005《信息技術 中文編碼字符集》,是中華人民共和國現時最新的內碼字集,與 GB 2312-1980 完全兼容,與 GBK 基本兼容,支持 GB 13000 及 Unicode 的全部統一漢字,共收錄漢字 70244 個。現行版本為國家質量監督檢驗總局和中國國家標準化管理委員會于2005年11月8日發布,2006年5月1日實施,為在中國境內所有軟件產品支持的強 制標準。

(以上資料來源于“維基百科”)

二、隨機生成常用漢字的 C# 程序

新建Java項目,創建代碼片段:

import java.io.UnsupportedEncodingException;
import java.util.Random;

/**

  • 隨機生成常見的漢字
  • @author xuliugen
  • */ public class GeneCharTest { public static void main(String[] args) {

     for (int i = 1; i < 24; i++) {
         System.out.print(getRandomChar() + "  ");
     }
    

    }

    private static char getRandomChar() {

     String str = "";
     int hightPos; //
     int lowPos;
    
     Random random = new Random();
    
     hightPos = (176 + Math.abs(random.nextInt(39)));
     lowPos = (161 + Math.abs(random.nextInt(93)));
    
     byte[] b = new byte[2];
     b[0] = (Integer.valueOf(hightPos)).byteValue();
     b[1] = (Integer.valueOf(lowPos)).byteValue();
    
     try {
         str = new String(b, "GBK");
     } catch (UnsupportedEncodingException e) {
         e.printStackTrace();
         System.out.println("錯誤");
     }
    
     return str.charAt(0);
    

    } }</pre>

 本文由用戶 gww3 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!