IO简述
IO是相对程序而言的,也就是说往程序里边输入就是in,往程序外读出就是out。
数据的读取只能从头到尾的读写。
并且输入输出流只能单向流动,也就是说读取的时候只能读取,写入的时候只能写入。
数据操作的单位有两种:字节流和字符流。
字节流和字符流的区别
字符流只能用于操作字符文件(/txt)
字节流可以操作所有文件(文本,图片,音频,视频)
原因在于字符流是操作的文本文件,我们在读写的时候很容易因为编码问题导致出现乱码,所以一般情况下会指定编码集UTF-8;字节流是以二进制的形式进行输入输出的。
简单的文件操作
File file = new File("D:\\java\\study\\1.txt");
//获取文件长度
System.out.println(file.length());
//获取文件名称
System.out.println(file.getName());
//获取是否是文件
System.out.println(file.isFile());
//获取是否是文件夹
System.out.println(file.isDirectory());
//获取文件路径
System.out.println(file.getPath());
//获取文件是否存在
System.out.println(file.exists());
//获取上一级目录(父路径)
System.out.println(file.getParent());
//获取完整路径
System.out.println(file.getAbsolutePath());
//新建文件
File f1 = new File("D:\\java\\study\\2.txt");
System.out.println((f1.createNewFile()));
//新建单层不存在的文件夹
file = new File("D:\\java\\study1\\WXN");
System.out.println(file.mkdir());
//新建多层不存在的文件夹
System.out.println(file.mkdirs());
//删除文件
System.out.println(f1.delete());
//返回String[] 包含文件名
file = new File("D:\\java\\study");
String[] S = file.list();
for(String a : S){
System.out.print(a+" ");
}
System.out.println();
//返回file[],包含文件对象
File[] E = file.listFiles();
for(File a : E){
System.out.print(a+" ");
}
一大波方法又一次闯入我们的生活…
文件的读入
首先我们要知道文件的写入写出需要一个工具类:InputStream(所有读取流的父类)也是一个抽象类。
当然我们再具体做文件输入输出的时候我们使用的是:FileInputStream
文件内容的读入方式
1.方法一:用FileInputStream
// File file = new File("D:\\java\\study\\1.txt");
InputStream fis1 = new FileInputStream("D:\\java\\study\\2.txt");
// InputStream fis2 = new FileInputStream(file);
// fis1.read();//一次读入一个数据
//fis1.read(c);//读入到一个数组
// fis1.read(c,1,5);//从第一个开始读取,读入长度为5
int b =0;
while((b=fis1.read())!=-1){
System.out.println(b);
}
2.方法二:用BufferedInputStream
InputStream in = new BufferedInputStream(
new FileInputStream("D:\\java\\study\\2.txt"));
int b=0;
while((b=in.read())!=-1){
System.out.println(b);
}
in.close();
这时候一些人可能要说了,啊,博主,两者的写法几乎一模一样,而且第二个似乎比第一个还要麻烦,有写的必要吗?这个自然是有的,甚至第二种方法比第一种方法要好得多。
FileInputStream和BufferedInputStream的区别
1.FileInputStream则是每一次调用read会从文件中进行读取。
2.BufferedInputStream 有个内部缓冲区当read时会先把缓冲区填满(默认缓冲区是8192,然后下次读取是直接从缓冲区读取。当读取的位置大于缓冲区时会再一次加载缓冲区。
所以我们可以知道BufferedInputStream 的读取速度会快很多。这个也可以去看源码去看看到底的原理是什么。

我知道一部分人不会去翻…我把带有缓冲区的这一部分放在这里。
文件的写出
1.方法一:用FileInputStream
OutputStream out = new FileOutputStream("D:\\java\\study\\2.txt");
byte[] c = {'w','x','n'};
// out.write('w');//一次传入一个数字
out.write(c);//传入一个数组的数据
// out.write(c,1,5);//从第一个开始,传入长度为5
out.close();
2.方法二:用BufferedInputStream
OutputStream out = new BufferedOutputStream(
new FileOutputStream("D:\\java\\study\\2.txt"));
byte[] c = {'w','x','n'};
out.write(c);
out.close();
本文详细介绍了Java IO中的字节流和字符流的区别,以及如何通过File类进行基本文件操作,包括文件长度、路径管理、创建和删除等,并对比了 FileInputStream和BufferedInputStream的使用技巧。
&spm=1001.2101.3001.5002&articleId=112653591&d=1&t=3&u=4c1e9287b09444b5a1697cd612e8ab28)
422

被折叠的 条评论
为什么被折叠?



