<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    snowolf

    這樣的一種生活
    posts - 23, comments - 5, trackbacks - 0, articles - 11

    精確截取字符串(轉(zhuǎn)載)

    Posted on 2006-06-13 10:46 snowolf 閱讀(871) 評論(0)  編輯  收藏 所屬分類: 學(xué)習(xí)
    開發(fā)中經(jīng)常遇到,字符串過長,無法完全顯示的問題

    這時候就需要截取我們所需要的長度,后面顯示省略號或其他字符。

    由于中文字符占兩個字節(jié),而英文字符占用一個字節(jié),所以,單純地判斷字符數(shù),效果往往不盡如人意

    下面的方法通過判斷字符的類型來進(jìn)行截取,效果還算可以:)


    如果大家有其他的解決方法歡迎貼出來,共同學(xué)習(xí):)
    **********************************************************************
    private String str;
    private int counterOfDoubleByte;
    private byte b[];
    /**
    * 設(shè)置需要被限制長度的字符串
    * @param str 需要被限制長度的字符串
    */
    public void setLimitLengthString(String str){
    ? this.str = str;
    }
    /**
    * @param len 需要顯示的長度(<font color="red">注意:長度是以byte為單位的,一個漢字是2個byte</font>)
    * @param symbol 用于表示省略的信息的字符,如“...”,“>>>”等。
    * @return 返回處理后的字符串
    */
    public String getLimitLengthString(int len, String symbol) throws UnsupportedEncodingException {
    ? counterOfDoubleByte = 0;
    ? b = str.getBytes("GBK");
    ? if(b.length <= len)
    ??? return str;
    ? for(int i = 0; i < len; i++){
    ??? if(b[i] < 0)
    ????? counterOfDoubleByte++;
    ? }

    ? if(counterOfDoubleByte % 2 == 0)
    ??? return new String(b, 0, len, "GBK") + symbol;
    ? else
    ??? return new String(b, 0, len - 1, "GBK") + symbol;
    }


    本文轉(zhuǎn)貼自網(wǎng)友:focus2004 的文章

    #?re: 精確截取字符串(轉(zhuǎn)載) 2006-01-28 18:24 tdg
    大作拜讀,有一點(diǎn)愚見,特拋磚引玉:
    1。字符串除了可以基于byte[]操作外,還可以基于char[]操作。看老大你的意圖是想截取字符串的前幾個字符然后加上省略符號最后輸出而已,完全不必考慮用byte[]數(shù)組操作啊 。而且好像開發(fā)中更注重語義上的第幾個字符而不是你說的這種情況哦。
    2。以下是拙作,請斧正:
    /**
    * 字符串截取函數(shù)
    * @param str String 要處理的字符串
    * @param length int 需要顯示的長度
    * @param symbol String 用于表示省略的信息的字符,如“...”,“>>>”等
    * @return String 返回處理后的字符串
    * @throws UnsupportedEncodingException
    */
    public String getLimitLengthString(String str, int length, String symbol) throws
    UnsupportedEncodingException {
    assert str != null;
    assert length > 0;
    assert symbol != null;
    //如果字符串的位數(shù)小于等于要截取的位數(shù),附加上表示省略的信息的字符串后返回
    if (str.length() <= length) {
    return str + symbol;
    //從零開始,截取length個字符,附加上表示省略的信息的字符串后返回
    } else {
    str = new String(str.getBytes("GBK"));
    char[] charArray = str.toCharArray();
    char[] charArrayDesc = new char[length];
    System.arraycopy(charArray, 0, charArrayDesc, 0, length);
    return new String(charArrayDesc) + symbol;
    }
    }??

    呵呵 tdg 兄很認(rèn)真喔,談不上斧正。主要是這個問題,用 char 處理,如果是字母或者數(shù)字,實(shí)際上截取出來的會比漢字少占用一半的空間,所以截取出來后,還是不能對齊。而實(shí)際上 char 數(shù)組中,不管是字母、數(shù)字還是漢字,它們都只代表一個單元。但是 byte 則不同,字母、數(shù)字只占用一個字節(jié),而漢字占用兩個字節(jié)(都是GBK編碼)。??

    您好!
    你的文章讓我受益不少,有個問題想向您確認(rèn)一下:
    在代碼中
    b = str.getBytes("GBK");
    if(b.length <= len)
    return str;
    for(int i = 0; i < len; i++){
    if(b[i] < 0)
    counterOfDoubleByte++;
    }
    是不是如果只要是中文漢字,在b[i]對應(yīng)的值都是小于0的,
    也就是說,在漢字代表的兩個字節(jié)中,這兩個漢字分別轉(zhuǎn)化為整數(shù)值時,是不是一定小于0,但值范圍不能小于-127的。做過測試,不能肯定。:)

    istarliu,這里要強(qiáng)調(diào)一下,GBK、GB2312 雙字節(jié)編碼字節(jié)才是負(fù)的。UTF-8 三字節(jié)編碼未去核實(shí)。

    來源
    主站蜘蛛池模板: 99久久免费国产精精品| 亚洲av无码日韩av无码网站冲| 亚洲阿v天堂在线2017免费 | 亚洲日本中文字幕| 国产在线一区二区综合免费视频| 久久精品国产精品亚洲| 国产精品永久免费| 久久青青草原亚洲AV无码麻豆 | 免费看一级高潮毛片| 亚洲AⅤ视频一区二区三区| 人妻巨大乳hd免费看| 亚洲日韩激情无码一区| 免费人成毛片动漫在线播放| 亚洲AV成人片色在线观看 | 亚洲最大av资源站无码av网址| 毛片在线免费视频| jzzijzzij在线观看亚洲熟妇| 免费成人av电影| 伊人久久大香线蕉免费视频| 亚洲成在人天堂一区二区| 综合在线免费视频| 久久亚洲精品无码网站| 亚洲精品无码永久在线观看| 久久国产精品成人免费| 亚洲最大黄色网址| 国产精品成人无码免费| 中文永久免费观看网站| 亚洲自偷自拍另类图片二区| 国产三级在线观看免费| 一级毛片在线完整免费观看| 久久精品亚洲中文字幕无码网站| 亚洲免费闲人蜜桃| 色妞www精品视频免费看| 久久亚洲精品中文字幕三区| 免费阿v网站在线观看g| 美女黄色免费网站| 91精品国产亚洲爽啪在线观看| 国产免费AV片无码永久免费| 日韩精品无码免费专区网站 | 亚洲中文字幕无码日韩| 亚洲精品免费在线观看|