idea中使用Inputstream流导致中文乱码解决方法
程序员文章站
2022-03-10 17:05:50
1.问题描述idea中使用inputstream流导致中文乱码解决方法,当然也不一定就是输入流,可能输出流或者其他用到了流相关的字符的都可能出现乱码,这里有一个可能的解决办法。2. 解决办法① ide...
1.问题描述
idea中使用inputstream流导致中文乱码解决方法,当然也不一定就是输入流,可能输出流或者其他用到了流相关的字符的都可能出现乱码,这里有一个可能的解决办法。
2. 解决办法
① idea中找到下面的路径
file--settings--editor--file encodings
② transparent native-to-ascii conversion把这个前面勾上,重新创建文件,执行就ok
很多朋友遇到java fileinputstream读中文乱码问题,下面小编在给大家普及下这方便的知识及解决方法。
1、前提
以读取编码是gbk的文件为案例,文件内容只有中文和中文符号
2、原因
fileinputstream读中文乱码是因为一个中文对应两个字节存储(负数),也就是说,读取对应中文的字节数应该是偶数; 而英文对应一个字节存储。fileinputstream每次读取一个数组长度的字节时,读取的中文字节数可能是奇数,也就是只读到中文的一半字节,出现乱码。
3、解决方法
一次读取所有字节,此方法不靠谱,因为不确定总字节数。
在输出时进行判断,遍历数组判断负数的个数,如果是奇数,说明读取到中文的一半字节,对数组进行扩容再输出;否则正常输出
4、代码案例
package 第二题; import java.io.file; import java.io.fileinputstream; import java.io.filenotfoundexception; import java.io.ioexception; import java.io.unsupportedencodingexception; import java.util.arrays; public class maintest { public static void main(string[] args) throws unsupportedencodingexception { // 创建file对象 file file = new file("d:\\filetest\\file4.txt"); fileinputstream fileinputstream = null; try { // 新建一个fileinputstream对象 fileinputstream = new fileinputstream(file); // 新建一个字节数组 byte[] buf = new byte[2]; // read(buf):此方法的返回值就是当前读取的字节个数,将数据读取到buf数组 // 将readlen变量也就是read方法的返回值,当此变量等于-1,则读到文件末尾 int readlen = -1; //读取文件数据 while ((readlen = fileinputstream.read(buf)) != -1) { int pos=0;//记录负数的个数 for(byte v:buf) { if(v<0) { pos++; } } //负数个数为偶数,读取完整,没有读取到半个中文 if(pos%2==0) { // 将字节数组转换成字符串 string content = new string(buf, 0, readlen); system.out.print(content); }else {//负数个数为奇数,读取不完整,会乱码 //再读取下一位字节 int nextbytevalue=fileinputstream.read(); int nextlen=readlen+1; //字节数组扩容一位 buf= arrays.copyof(buf,nextlen); buf[readlen]= (byte) nextbytevalue; string content=new string(buf,0,nextlen); system.out.print(content); //奇数,字节补全 //针对数组扩容一个字节单元 /* buf=arrays.copyof(buf, readlen+1); int nextbytevalue=fileinputstream.read(); buf[readlen]= (byte) nextbytevalue; string content = new string(buf, 0, readlen); system.out.print(content);*/ } } } catch (filenotfoundexception e) { // 输出堆栈信息 e.printstacktrace(); } catch (ioexception e) { e.printstacktrace(); } finally { try { // 文件输入流关闭(释放资源) fileinputstream.close(); } catch (ioexception e) { // todo auto-generated catch block e.printstacktrace(); } } } }
以上就是idea中使用inputstream流导致中文乱码解决方法的详细内容,更多关于idea inputstream流乱码的资料请关注其它相关文章!