`
BabyDuncan
  • 浏览: 574341 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java按照字节数截取含有中文的字符串

    博客分类:
  • J2SE
阅读更多
要求:
编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 但是要保证汉字不被截半个,如"我ABC"4,应该截为"我AB",输入"我ABC汉DEF",6,应该输出为"我ABC"而不是"我ABC+汉的半个"。
package MSB_Problems;

public class splitStringWithChinese {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String s = "我zgh赵huohao";
		getString(s,6);
	}
	public static void getString(String s,int num){
		int k=0;
		String temp="";
		for (int i = 0; i <s.length(); i++)
		{	
			byte[] b=(s.charAt(i)+"").getBytes();
			k=k+b.length;
			if(k>num)
			{
				break;
			}
			temp=temp+s.charAt(i);			
		}	
		System.out.println(temp);
	}
}


解释:中文汉字一个占两个字节,英文占一个字节,比如这个s字符串,所占字节数是13,而长度是11,为了不截取到半个汉字,需要随时判断截取串所占的字节数
(s.charAt(i)+"").getBytes().length即可判断这个字符所占的字节数,比如i=0,那么此表达式的结果为2,i=1,则结果为1。、
为什么要加“”呢,就是要把char转换成String啊。。
String.valueOf(source.charAt(i))也可以的。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics