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

使用字符流包装字节流时,
如果没有设置字符集,默认使用环境变量相关的字符集进行转码,

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

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


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

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

@Test
	public 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();
			}
		}
	}


你可能感兴趣的:(io)