<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í)。

    來源
    主站蜘蛛池模板: 国产福利在线观看免费第一福利| 亚洲综合伊人制服丝袜美腿| 无码AV片在线观看免费| 亚洲国产夜色在线观看| 永久免费av无码网站大全| 无码毛片一区二区三区视频免费播放 | 久久精品国产精品亚洲人人 | 国产乱子伦精品免费视频| 久久久久亚洲av无码专区导航| 日韩精品成人无码专区免费 | 毛片免费全部播放一级| gogo免费在线观看| 亚洲成人在线免费观看| 亚洲精品视频免费| 免费av欧美国产在钱| 丁香花在线观看免费观看图片 | 中文字幕在线观看免费视频 | 三根一起会坏掉的好痛免费三级全黄的视频在线观看 | 亚洲1区2区3区精华液| 在线观看免费大黄网站| 亚洲资源在线观看| 成年女人午夜毛片免费视频 | 亚洲综合日韩久久成人AV| 国产电影午夜成年免费视频| 色一情一乱一伦一视频免费看| 亚洲黄色免费在线观看| 亚洲一级片内射网站在线观看| 一本无码人妻在中文字幕免费| 青青操免费在线视频| 天天综合亚洲色在线精品| 亚洲人成片在线观看| 亚洲VA中文字幕不卡无码| 亚洲国产成人久久一区WWW| 99爱在线精品免费观看| 久久久久免费精品国产| 五月婷婷免费视频| 亚洲avav天堂av在线网毛片| 亚洲欧洲自拍拍偷午夜色| 亚洲AV无码久久寂寞少妇| 亚洲愉拍99热成人精品热久久| 免费A级毛片无码A∨男男|