java第二十二课

Java 的字节流
把数据从程序存储到文件,把数据从文件读取程序中
File
只操作文件和文件属性
createNewFile
getPath--->
项目目录
getAbsolutePath()
getName()----->substring()

list()-->列出当前目录的所有文件或文件夹,返回值 String[]
返回只有文件名,路径可以拼接
listFiles()----列出当前目录的所有文件或文件夹,返回值是
File[],调用 File 的方法去进行处理
字节流
返回的整型 int
输入流 FileInputStream read 方法 最后关闭 close
输出流 FileOutputStream write 方法 最后关闭 close

性能指标参考
System. currentTimeMillis(),具体的时间戳.
实际处理问题,一般是有缓存,定义一个字节数组 byte[]
系统提供了缓存的类
BufferInputStream-->(FileReader)FileInputStream-->File
缓存输入类 BufferedInputStream

缓存输出类 BufferedOutputStream
底层写缓存的方法,与我们自己定义字节数组缓存思想一样.
BufferedInputStream 缓存数字是 8192 (8K)
文件内容放在 Buffer 中,读的时候用 BufferedInputStream,
写的时候用 BufferOutputStream
字节流处理文件传输
字符流,专门针对于文本文件处理
FileReader->FileInputStream-->File
底层是 Reader 类
FileWriter
底层是 Writer 类
实质还是字节,只不过处理过程用 char
Reader 的缓存类 BufferedReader
这个类中 readLine,读文本文件处理,往往项目需求按行读
Buffer,使用缓存,write 后一定 flush(),如果关闭,自动 flush()
在应用缓存的开发中,这里有三种操作:剪切,复制,粘贴。
剪切,复制对文字是 100%有效,字符流更好保证了剪切,
复制,粘贴。
不执行 flush(),数据在缓存中,flush()之后数据变成实际的文

剪切是不清楚这个文件剪切,剪切是不保存文件的,
剪切逻辑:

首先把文件全部在缓存中,不执行 flush()方法,只有粘贴时
执行 flush 方法
这里报错,New Writer 里面传 File,File 没有路径是做不了
的.相当于剪切必须知道剪切到哪里.实际操作是不知道路
径的,就必须有一个路径先有效,后期把路径覆盖.
所以每个人电脑都有一个预先的路径设置,预先设置的路径
是临时文件.(tmp)
文件剪切,执行文件到缓存中,同时在源路径删除
实际开发,用 buffer 产生临时文件.
执行到粘帖时,把缓存中的数据 flush 就可以。
剪切,一定需要 Buffer

java第二十二课 · WL—code/WL仓库 - Gitee.com

你可能感兴趣的:(java,开发语言)