扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
Java内核是unicode的,就连class文件也是,但是很多媒体,包括文件/流的保存方式是使用字节流的。
因此Java要对这些字节流经行转化。
char是unicode的,而byte是字节。我们在写JSP页面时可能没注意到JSP作为回显终端,也是byte的,所以在从JSP页面中读取表单和写入数据
(Javabean)时要注意页面的编码.
一个传统的解决方案是所有的应用包括页面编码设置\数据库编码设置都设定一致,比如gbk(gbk是gb2312的扩展集,支持的字符要多些).
现在又有个问题了,既然Java内核是unicode的编码,那么字符串String lml="我爱金信桥tbs,tbs金信桥爱我"的长度应该是中文字符和英文字符的个数和,即lml.length()==17.
好了,如果我们想截取长度为14的字符串,那么应该:lml.substring(0,13);返回“我爱金信桥tbs,tbs金”.
这没问题吧?
但如果是应用中要求我们截取"固定回显长度"的字符串回显到JSP页面,那应该怎么办呢?所谓“固定回显长度”是指一个区域纯英文能显示x个,纯中文能显示x/2个.假设一个JSP页面中,有个表格,其中一列宽度为13个纯英文字符,我们想显示主题,主题可以为中文或英文.如果我们简单地设定了取前13个字符,那么在英文情况下是没问题的,能正确显示截取的前13个.
但汉字呢?一个汉字要占两个英文的宽度的.所以取了13个汉字就超过了列的宽度,破坏了布局.
那取6个字符好了!
恩,这到是没破坏布局,但你不觉得英文的情况下浪费了一般的宽度么?
哦,那就不好办了,中英文混合的串确实麻烦...
我在做mail系统时,在邮件列表中有一列加上了正文的内容提示(前50个字符,有点类似gmail),内容是可以有中文和英文混合的,所以为了尽量提示多些,不能采
用笨方法:直接取25个字符,保证中文没问题,英文浪费去吧~~~
后来仔细研究了一下,可以这样解决:从字符串转换成byte,然后判断汉字的个数,是汉字就取占两个空,不是汉字就占一个空.这就是为什么一开
始我要提提Java中的byte<---->char,o(∩_∩)o...哈哈
注意到这里有个trick,就是如果最后截取的是半个汉字,要丢弃掉!!否则,最后可能出现一个?号.
用法:
string str=MyUtil.substring(lml,14);
System.out.println(str);
输出:
我爱金信桥tbs,
核心代码如下:
|
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者