(三十一)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包中还有很多其他的流,流的作用主要是为了改善程序性能并且使用方便