字符流读取文本文件的编码问题

来源:互联网 发布:淘宝优惠券qq群 编辑:程序博客网 时间:2024/04/29 06:45
使用字符流包装字节流时,
如果没有设置字符集,默认使用环境变量相关的字符集进行转码,

这样会出现代码移植的不确定性,所以应该在实例化字符流时自己设定字符集

new InputStreamReader(InputStream,Charset.forName("UTF-8"))


FileReader实例化时不能指定字符集,它只能使用默认的编码,

所以读取文本文件时最好使用new InputStreamReader(new FileInputStream(),Charset)方式取代new FileReader()

@Testpublic void test01(){BufferedReader reader=null;try {String str=null;String filePath="E://test.txt";//文件使用UTF-8编码reader=new BufferedReader(new InputStreamReader(new FileInputStream(filePath)));str=reader.readLine();System.out.println("使用默认编码:"+str);reader=new BufferedReader(new InputStreamReader(new FileInputStream(filePath),Charset.forName("GBK")));str=reader.readLine();System.out.println("使用GBK编码:"+str);reader=new BufferedReader(new InputStreamReader(new FileInputStream(filePath),Charset.forName("UTF-8")));str=reader.readLine();System.out.println("使用UTF-8编码:"+str);reader=new BufferedReader(new FileReader(filePath));str=reader.readLine();System.out.println("使用FileReader读取:"+str);} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally{try {reader.close();} catch (IOException e) {e.printStackTrace();}}}


0 0
原创粉丝点击