import java.io.UnsupportedEncodingException; /** * 十、 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 * 可是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,6,应该输出为“我ABC”而不是“我ABC+汉的半个”。 * * @author 呆呆 彷佛还有其余问题,随后在修改。 */ public class Test10 { public static void main(String[] args) throws UnsupportedEncodingException { String srcStr1 = "我ABC"; String srcStr2 = "我ABC汉DEF"; String srcStr3 = "我"; splitString(srcStr1, 4); splitString(srcStr2, 7); splitString(srcStr3, 1); splitString(srcStr1, 10); splitString(srcStr3, 2); } public static void splitString(String src, int len) throws UnsupportedEncodingException { int byteNum = 0; if (null == src) { System.out.println("The source String is null!"); return; } byteNum = src.length(); byte bt[] = src.getBytes("gbk"); // 将String转换成byte字节数组 if (len >= bt.length) { System.out.println("len:"+src); return; } // 判断是否出现了截半,截半的话字节对于的ASC码是小于0的值 if (bt[len-1] < 0) { if(len-2 >= 0 && bt[len-2] < 0){ String subStrx = new String(bt, 0, len,"gbk"); System.out.println("subStrx==" + subStrx); }else if (len - 2 < 0){ System.out.println("subStrx== " + ""); }else{ String subStrx = new String(bt, 0, len-1,"gbk"); System.out.println("subStrx==" + subStrx); } } else { String subStrx = new String(bt, 0, len,"gbk"); System.out.println("subStrx==" + subStrx); } } }