java使用filereader.read()读取文件时乱码
public class filereader_ {
public static void main(string[] args) {
}
@test
public void m1() {
string filepath = "e:\\hello.txt";
filereader filereader = null;
try {
filereader = new filereader(filepath);
//循环读取 使用read
while (filereader.read()!=-1){
system.out.print((char) filereader.read());//默认输出的是int,因此需要转化为char
}
} catch (ioexception e) {
e.printstacktrace();
} finally {
try {
if (filereader != null) {
filereader.close();
}
} catch (ioexception e) {
e.printstacktrace();
}
}
}
}以上代码是有可能出现代码输出混乱的情况的,输出效果如下:

可能会出现乱码的问题
原因可能是文件编码与程序读取时使用的编码不一致。
在创建filereader对象时,没有指定文件的编码格式,因此默认使用的是系统默认的编码格式。
如果文件中包含非系统默认编码格式的字符,那么在读取时就会出现乱码。
解决过程
为了解决这个问题,可以在创建filereader对象时指定文件的编码格式。
例如,如果文件是使用utf-8编码的,可以这样修改代码:
public void m1() {
string filepath = "e:\\hello.txt";
filereader filereader = null;
int data = 0;
try {
// 指定字符编码为utf-8
filereader = new filereader(filepath, standardcharsets.utf_8);
//循环读取 使用read
while ((data=filereader.read())!=-1){
system.out.print((char) data); // 修改这里
}
} catch (ioexception e) {
e.printstacktrace();
} finally {
try {
if (filereader != null) {
filereader.close();
}
} catch (ioexception e) {
e.printstacktrace();
}
}
}
上面这种方法,按理说也可以,但是我使用后发现报错了,不能调用utf-8,感兴趣的小伙伴,自行尝试 ~
在java中,filereader.read()方法返回的是读取到的字节(int类型),而不是字符(char类型)。因此,需要使用强制类型转换将其转换为字符。
我们需要使用int类型的date来,接受filereader.read(),当接受的数据不为空时,一直循环下去,直到接受到最后一个字符,然后每接受一个数据,就强制转换成 char 打印到控制台,就不会出现乱码的情况了
public class filereader02_ {
public static void main(string[] args) {
}
@test
public void m1() {
string filepath = "e:\\hello.txt";
filereader filereader = null;
int date=0;
try {
filereader = new filereader(filepath);
//循环读取 使用read
while ((date=filereader.read())!=-1){
system.out.print((char) date);
}
} catch (ioexception e) {
e.printstacktrace();
} finally {
try {
if (filereader != null) {
filereader.close();
}
} catch (ioexception e) {
e.printstacktrace();
}
}
}
}
控制台打印输出:

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论