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

国际化字符串

阅读更多

一.虽然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位置,只不过这里直接用的十进制而已。

 

好的,介绍完收工了。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics