|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
这是张孝祥老师的java就业培训视频教程里面的一道题目(有所变动): 编写下面的程序代码,分析和观察程序的运行结果: import java.io.*; public class TestCodeIO { public static void main(String[] args) throws Exception{ InputStreamReader isr = new InputStreamReader(System.in,"iso8859-1"); BufferedReader br = new BufferedReader (isr); String strLine = br.readLine(); br.close(); isr.close(); System.out.println(strLine); } } 运行程序后,输入“中国”两个字,输出结果为 ???ú 请按照下面两种方式修改上述程序,是输入的中文能够正常输出 1。修改程序中的语句 InputStreamReader isr = new InputStreamReader(System.in,"iso8859-1"); 2。不修改上面的语句,修改下面的语句 System.out.println(strLine); 第一种该法很简朴,只要改成下面这样就可以了,这里不具体讨论 InputStreamReader isr = new InputStreamReader(System.in,"gb2312"); 这里我要具体讨论的是第二种该法怎么改 起初我是这样改的 System.out.println(new String (strLine.getBytes(),"iso8859-1")); 输入“中国”后输出的结果虽然不是上面所述的乱码,但是还是乱码,显然这种该法是不准确的! 这里我要感谢 软件民工 告诉我的准确改法,使我恍然大悟 System.out.println(new String (strLine.getBytes("iso8859-1"))); 这两种改法毕竟有什么区别呢?为了方便大家阅读,我先把准确和错误的改法帖出来: import java.io.*; public class TestCodeIO { public static void main(String[] args) throws Exception{ InputStreamReader isr = new InputStreamReader(System.in,"iso8859-1"); //Create an InputStreamReader that uses the given charset decoder BufferedReader br = new BufferedReader (isr); String strLine = br.readLine(); br.close(); isr.close(); System.out.println(strLine); System.out.println(new String (strLine.getBytes(),"iso8859-1"));//错误改法 //Encodes this String (strLine) into a sequence of bytes using the platforms //default charset(gb2312) then constructs a new String by decoding the //specified array of bytes using the specified charset (iso8859-1) //because this String (strLine) uses the charset decoder "iso8859-1",so it can //only be encoded by "iso8859-1",cannt be encoded by the platforms default //charset "gb2312",so this line is wrong. System.out.println(new String (strLine.getBytes("iso8859-1")));//准确改法 //Encodes this String (strLine) into a sequence of bytes using the named //charset (iso8859-1),then constructs a new String by decoding the //specified array of bytes using the platforms default charset (gb2312). //This line is right. } } 上面的英文注释已经说得很清晰了,这里我还是解释一下吧: 首先是错误的改法 System.out.println(new String (strLine.getBytes(),"iso8859-1")); 这句代码是将strLine中的字符串用系统默认的编码方法(这里是gb2312) 转变为字节序列,然后用指定的编码方法(这里是iso8859-1)构造一个新的 String对象,并打印到屏幕上。 错误在哪里呢? 请注重这一段代码 InputStreamReader isr = new InputStreamReader(System.in,"iso8859-1"); BufferedReader br = new BufferedReader (isr); String strLine = br.readLine(); 这里strLine存储的内容是用指定的编码方法(iso8859-1)存储的,而转变成字节码 的时候(这句代码strLine.getBytes())却使用了系统默认的gb2312编码,所以当然就 输出乱码了!然后用gb2312编码的字节序列构建新的String对象的时候又使用了 iso8859-1编码,所以输出的乱码和System.out.println(strLine)有所不同。 至于准确的改法就不用具体说明了吧,首先将strLine用iso8859-1编码方法转变成字节 序列,然后用系统默认的编码方法(gb2312)构建新的String对象,然后打印输出。 返回类别: 教程 上一教程: 新Java技术工具亮相游戏开发商大会 下一教程: 易混淆的几个JAVA术语(转贴) 您可以阅读与"关于java中字符编码的一点心得,可能对初学者有点帮助"相关的教程: · java函数传值的一点心得 · JAVA里字符编码的探索与理解 · Java的Package与Import机制之我的理解(初学者的心得) · 关于学习JAVA的一点经验 · Java 字符编码问题 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |