rt,以下代码为例
DataInput d = new DataInputStream(System.in);
String line;
while((line = d.readLine()) != null)
{
System.out.println(line); //如果输入有中文,这里打印出来的是乱码。
}
DataInput d = new DataInputStream(System.in);
String line;
while((line = d.readLine()) != null)
{
System.out.println(line); //如果输入有中文,这里打印出来的是乱码。
}
改成這樣試下
DataInput d = new DataInputStream(System.in,"gbk");
DataInputStream没有这个构造函数。本以为
System.out.println(new String(line.getBytes("ISO-8859-1"),"utf-8"));可以解决,但是还是不行。
已过时。 该方法无法将字节正确转换为字符。从 JDK 1.1 开始,读取文本行的首选方法是使用 BufferedReader.readLine() 方法。使用 DataInputStream 类读取文本行的程序可以改为使用 BufferedReader 类,只要将以下形式的代码:
DataInputStream d = new DataInputStream(in);
替换为:
BufferedReader d = new BufferedReader(new InputStreamReader(in));
System.out.println(br.readLine());
没看见乱码在哪
BufferedReader d = new BufferedReader(ins);
String line;
while((line = d.readLine()) != null)
{
System.out.println(line); //如果输入有中文,这里打印出来的是乱码。
}
byte[] bb = new byte[12];
d.readFully(bb);
System.out.println(new String(bb, "gbk"));不过前提是有大于等于所建字节数组长度的流输入
还有些其他方法的