(三十一)javaIO流的实现机制是什么

一、字节流读写(FileInputStream、FileOutputStream)

public static void main(String[] args) throws IOException {
		//字节流的读 inputstream
		FileInputStream fis=new FileInputStream("C:/Users/ASUS/Desktop/Woman.java");
		FileOutputStream fos=new FileOutputStream("C:/Users/ASUS/Desktop/1.txt");
		byte[] buf=new byte[40];
		
		int len=0;//每次读取的长度
		while((len=fis.read(buf))!=-1)
		{
			//System.out.println(new String(buf,0,len));//String(byte[] bytes, int offset, int length)
			fos.write(new String(buf,0,len).getBytes()); //将字符串转换成字符数组
		}
		
		
}

具体:https://blog.csdn.net/jiangshangchunjiezi/article/details/75675145

二、字节流读写(BufferedInputStream、BufferedOutputStream)

      带缓冲的字节输入流:上面我们知道文件字节输入流的读取时,是直接同字节流中读取的。由于字节流是与硬件(存储介质)进行的读取,所以速度较慢。而CPU需要使用数据时通过read()、read(byte[])读取数据时就要受到硬件IO的慢速度限制。我们又知道,CPU与内存发生的读写速度比硬件IO快10倍不止,所以优化读写的思路就有了:在内存中建立缓存区,先把存储介质中的字节读取到缓存区中。CPU需要数据时直接从缓冲区读就行了,缓冲区要足够大,在被读完后又触发fill()函数自动从存储介质的文件字节内容中读取字节存储到缓冲区数组。

           BufferedInputStream 内部有一个缓冲区,默认大小为8M,每次调用read方法的时候,它首先尝试从缓冲区里读取数据,若读取失败(缓冲区无可读数据),则选择从物理数据源 (譬如文件)读取新数据(这里会尝试尽可能读取多的字节)放入到缓冲区中,最后再将缓冲区中的内容返回给用户.由于从缓冲区里读取数据远比直接从存储介质读取速度快,所以BufferedInputStream的效率很高。

一、字符流BufferedReader、BufferedWriter

	FileReader fr=new FileReader("C:/Users/ASUS/Desktop/Woman.java");
		BufferedReader br=new BufferedReader(fr);
		
		FileWriter fw=new FileWriter("C:/Users/ASUS/Desktop/1.txt");
		BufferedWriter bw=new BufferedWriter(fw);
		String line;
		while((line=br.readLine())!=null)
		{
			//System.out.println(line);
			bw.write(line);
	       
		}
		bw.flush();
		bw.close();
		br.close();

二、Java中有几种类型的流

常见的流有两种,分别为字节流与字符流。其中,字节流继承于InputStream与OutputStream,字符流继承于Reader与Writer。在java.io包中还有很多其他的流,流的作用主要是为了改善程序性能并且使用方便

 

posted @ 2019-02-21 23:22  测试开发分享站  阅读(142)  评论(0编辑  收藏  举报