InputStream
OutputStream //这2个是一个一个字节的读和写。
Reader
Writer //这2个是一个一个字符的读和写。
这四个抽象类,
@Test
public void testoud() throws IOException {
File f=new File("E:\eclipse-jee-kepler-SR1-win32\workspace1\io_excetpion\src\com\yinhai\liyang\test.java");
Reader in=new FileReader("E:\eclipse-jee-kepler-SR1-win32\workspace1\io_excetpion\src\com\yinhai\liyang\test.java");
char ca[]=new char[(int) f.length()];//f.length()这个返回的是此文件的大小,也就是字节大小,当这个文件中有几个汉字的时候就会大几个空格
int a=in.read(ca);
String str=new String(ca,0,a); //所以在这里要用a来截断
System.out.println(str);
in.close();
}
@Test
public void testoud1() throws IOException {
File f=new File("E:\eclipse-jee-kepler-SR1-win32\workspace1\io_excetpion\src\com\yinhai\liyang\test.java");
InputStream in=new FileInputStream("E:\eclipse-jee-kepler-SR1-win32\workspace1\io_excetpion\src\com\yinhai\liyang\test .java");
byte[] ca=new byte[(int) f.length()]; //这里就不会出现上面这种情况
int a=in.read(ca);
String str=new String(ca);
System.out.println(str);
in.close();
}
书中有一句话:在字符流的操作中,所有字符都是在内存中形成的
由此可以理解为Reader的时候,先读一个字节,然后能成功转换成字符的话就是一个字符,不能的话再读一个字节来转成字符,这样就解决了汉字占2个字节的问题。
Writer写也一样,能转换成一个byte的就直接写,不能的就转换成2个byte来写。
总结:字符流的实质还是字节流。