WEB开发网
开发学院WEB开发Jsp 关于java中字符编码的一点心得,可能对初学者有点... 阅读

关于java中字符编码的一点心得,可能对初学者有点帮助

 2008-01-05 09:31:45 来源:WEB开发网   
核心提示:这是张孝祥老师的java就业培训视频教程里面的一道题目(有所变动):编写下面的程序代码,分析和观察程序的运行结果:import java.io.*;public class TestCodeIO {public static void main(String[] args) throws Exception{Input

  这是张孝祥老师的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");

Tags:关于 java 字符

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接