我们知道,java在编译的时候,会吧字符串自动编译成为Unicode。所以,我们在执行String str = "/u4e2d"的时候,输出的其实是中文的“中”字。而,我们在执行String str = //u4e2d的是,str才输出/u4e2d;因为,java的编译器自动识别了。
这两天,我遇到了一个这样的问题。就是我的程序要接收网上传来的Unicode源码,存到数据库中以后在显示出来。我发现,由于这些服务器传来的Unicode源码没有经过本地编译,所以java在输出的时候会输出Unicode源码,而不是期望中的汉字。网上给的一些办法比如改变服务器编码格式,改变字符在本地的编码格式,将字符串拆成字节或字符数组再组合起来等都不能解决这个问题。现在想想,其实这些方法都没有找到出现这个问题的根本原因,就是java的编译器。由于服务器传来的都是英文字符,所以跟编码格式没有一点关系。想解决这个问题必须要把服务器传来的字符串重新打乱成字符数组,然后根据Unicode编码的格式自己组合起来。
在普通的java工程中,使用Json包可以实现这个,具体看http://blog.chenlb.com/2009/07/java-unicode-to-chinese.html 这个博客有详细解释。但是我要在J2Me中实现,Json包引用的类库就不能再用了,试了好多办法,终于得到一个高人指点,嘿嘿。感谢高人。
可以看我在csdn上的提问,http://topic.csdn.net/u/20100331/20/ea040d52-ae5b-4338-9217-a6fc0f29a914.html,
具体方法如下(经自己稍加改动)
这样,就能得到已经编译过的Unicode字符了。
当然,这个方法能在任何java程序上运行,感觉比Json好用多了。