import java.io.UnsupportedEncodingException;
/**
* 10、 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。
* 但是要保证汉字不被截半个,如“我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);
}
}
}