rt,以下代码为例
DataInput d = new DataInputStream(System.in);
String line;
while((line = d.readLine()) != null)
{
     System.out.println(line); //如果输入有中文,这里打印出来的是乱码。
}

解决方案 »

  1.   

    DataInput d = new DataInputStream(System.in);
    改成這樣試下
    DataInput d = new DataInputStream(System.in,"gbk");
      

  2.   


    DataInputStream没有这个构造函数。本以为
    System.out.println(new String(line.getBytes("ISO-8859-1"),"utf-8"));可以解决,但是还是不行。
      

  3.   

    readLine() 
    已过时。 该方法无法将字节正确转换为字符。从 JDK 1.1 开始,读取文本行的首选方法是使用 BufferedReader.readLine() 方法。使用 DataInputStream 类读取文本行的程序可以改为使用 BufferedReader 类,只要将以下形式的代码: 
         DataInputStream d = new DataInputStream(in);
     替换为: 
         BufferedReader d = new BufferedReader(new InputStreamReader(in));
      

  4.   

    奇怪,BufferedReader 应该可以的。我这也不行了,我记得有个io流可以处理中文流的
      

  5.   

    BufferedReader br=new BufferedReader(new InputStreamReader(System.in,"gb2312"));
    System.out.println(br.readLine());
    没看见乱码在哪
      

  6.   

    InputStreamReader ins  = new InputStreamReader(System.in);
    BufferedReader d = new BufferedReader(ins);
    String line;
    while((line = d.readLine()) != null)
    {
            System.out.println(line); //如果输入有中文,这里打印出来的是乱码。
    }
      

  7.   

    如果不用任何解码流直接读取字节流后再处理的话DataInput d = new DataInputStream(System.in);
    byte[] bb = new byte[12];
    d.readFully(bb);
    System.out.println(new String(bb, "gbk"));不过前提是有大于等于所建字节数组长度的流输入
    还有些其他方法的