国际化字符串

一.虽然jdk提供了国际化属性文件的工具,而且eclipse也有编辑属性文件的插件来让我们方便的时候。但自己还是情不自禁的想自己写一个,或者说是描述怎样实现的原理。可以参考如下代码。

package test;

public class Test {

	public static void main(String[] args) throws Exception {
		try {
			String m = new String("中文测试");
			System.out.println(m);
			char[] c = m.toCharArray();
			for (int i = 0; i < c.length; i++)
				System.out.println(Integer.toHexString((int) c[i]));
		} catch (Exception e) {
			System.out.println(e.toString());

		}
	}
}

 运行上面的程序, 你会得到如下结果

中文测试
4e2d
6587
6d4b
8bd5

 那么属性文件中,“中文测试”的国际化unicode应该是什么样子呢,如下

\u4e2d\u6587\u6d4b\u8bd5

 

可见,转换其实很简单,就是把字符数组的每个元素转换成16进制的字符串,然后在前卖弄加上字符前缀“\u”就可以了。

 

二.好了, 现在知道属性文件中unicode表现形式。那么,个浏览器也是支持unicode的。 但是我们会很奇怪的发现,怎么同样的字,在属性文件中和在网页中不是一样的呢。现在我也先不求甚解一下。不过要告诉大家的是两者其实是一致的。如下把汉字  张 转换成在网页中可以显示的unicode编码

String s = "&#" + (int)'张' + ";";

 s的实际值将会是 “&#24352;”

我想通过表现转换表达式也应该看出来的,网页的和属性文件的不同点在于前缀不同,而且多加了一个后缀";"。而核心仍然是unicode位置,只不过这里直接用的十进制而已。

 

好的,介绍完收工了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值