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来写。
总结:字符流的实质还是字节流。