A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 郭帅帅 中级黑马   /  2014-5-20 19:49  /  1205 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 郭帅帅 于 2014-5-21 15:20 编辑
  1. package com.itheima;

  2. import java.io.ByteArrayInputStream;
  3. import java.io.ByteArrayOutputStream;
  4. import java.io.IOException;

  5. public class Test10 {

  6.         /**
  7.          * 这个是从网上借鉴来的,不是太懂
  8.          * 编写函数,从一个字符串中按字节数截取一部分,但不能截取出半个中文(GBK码表),例如:
  9.          * 从“HM程序员”中截取2个字节是“HM”,截取4个则是“HM程”,截取3个字节也要是"HM"而不要出现半个中文
  10.          * @param args
  11.          * @throws Exception
  12.          */
  13.         public static void main(String[] args) throws Exception {
  14.                 // TODO Auto-generated method stub
  15.                  String s = "HM程序员";
  16.                  System.out.println(subStrByByte(s, 3));           
  17.         }        
  18.         
  19.         //将截取字符串的方法封装成单独的函数;
  20.         public static String subStrByByte(String str, int bLen) throws Exception {
  21.                 //定义两个变量记录长度值;
  22.                    int preLen = 0;
  23.                    int len = 0;
  24.                    str = str.substring(0, bLen);
  25.                   
  26.                    //用GBK的码表将字符串添加到字节数组当中;
  27.                    byte[] b = str.getBytes("GBK");
  28.                    if(b.length == bLen) {
  29.                     return str;
  30.                    }
  31.                    //这个for循环里面的判断没搞懂!!!
  32.                    for(int i=0; i<str.length(); i++) {
  33.                            
  34.                            if(str.charAt(i) < 0 || str.charAt(i) > 127) {
  35.                                    len += 2;
  36.                            }
  37.                            else {
  38.                                     len += 1;
  39.                            }
  40.                            if(len > bLen) {
  41.                                     byte[] newB = new byte[preLen];
  42.                                     System.arraycopy(b, 0, newB, 0, preLen);
  43.                                     return new String(newB);
  44.                            }
  45.                            preLen = len;
  46.                            }
  47.                            return str;
  48.                         }
  49. }
复制代码

评分

参与人数 1技术分 +1 收起 理由
轻语。 + 1

查看全部评分

3 个回复

倒序浏览
for循环里面的判断没搞懂,求解答
回复 使用道具 举报
for(int i=0; i<str.length(); i++)   
{
     if(str[i] < 0 || str[i] > 127) //如果它是一个中文对应的字节
          len += 2;    //一个中文对应两个字节
     else
          len += 1;    //一个键盘字符对应一个字节
     if(len > bLen )  //如果已经达到要取得字节数
           {  
                      byte[] newB = new byte[preLen]; //创建一个存放指定字节数的字节数组
                      System.arraycopy(b, 0, newB, 0, preLen); //将指定长度为preLen的b数组中的字节拷贝到newB字节数组中
                        return new String(newB); //返回newB字节数组对应的字符串
           }
          else
             prelen  = len;  //否则记录现在已经取到的字节数
}

评分

参与人数 1技术分 +1 收起 理由
轻语。 + 1

查看全部评分

回复 使用道具 举报
Lin0411 发表于 2014-5-20 20:02
for(int i=0; i 127) //如果它是一个中文对应的字节
          len += 2;    //一个中文对应两个字节
     ...

if(str < 0 || str > 127) //如果它是一个中文对应的字节,,这句不够准确。不过还是谢谢你的解答!
老实说你是不是按照字面意思理解啊?呵呵,不过,我刚上网查到了,这样的判断不是说字节,而是字符。
0-127对应的是ASCII码表中的占一个字节的字符,除此之外就不是占一个字节的字符了
str<0||str>127的意思是判断汉字用的,因为汉字这种字符不在0-127之间。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马