eclipse中启动java程序默认字符集
今天做了一些连接IBM ctg接口,发现返回的中文字符串乱码,这在以前是没有的事情.于是调试了半天,终于发现问题了.
原因就在于我将eclipse工程的字符集编码全部改成UTF-8了,这样在java程序启动的时候,自动将Charset默认字符集设置成了U8编码,而不是我之前相当然的只要在windowsXp平台上跑的程序都默认是GBK那样.
?
后来在eclipse将该工程导出为jar包,在windows命令行下跑,这此时由于脱离了eclipse的托管环境,默认字符集是GBK.
?
所以改eclipse工程的字符集编码要慎重!一不留神,就会影响代码里面的"String".getBytes()方法.因为该方式使用的就是默认字符集.最好的方法就是使用明确的字符集,这样一点问题都没有了.
?
"String".getBytes("GBK")这样就行
?
后来几天,又发生了一个奇怪的问题,就是我的同事,和我的配置一模一样,结果他的机器上,固定返回GBK,不管怎么弄,都不会返回UTF-8.最后发现eclipse版本的不一致,我的是3.7,他的是3.6,不知道是不是eclipse在新版本中做了一些改进,在程序启动的时候设置了file.encoding属性.
?
这个还有待考察,不管怎么样,涉及到String与byte[]的转换时,必须要明确指明字符集,这样能最大限度的减少不必要的麻烦.