-----------
1、什么是io流
jdk统一了数据的读写操作
jdk专门设计了一套api,针对数据的存储设备进行数据的读写操作,由于这套api中所有的类都位于 java.io包中,所以我们习惯性地称之为io流。
面相对象:方法属于哪个对象,就看方法改变了哪个对象的属性。
由于将读写操作封装在io流中不是一种正常的面向对象设计,所以io流操作一定会有异常。
读取一个1500字节的文件:
第一次循环:将1024个字节通过in.read(buffer)读取至buffer中,len=1024
再通过out.write(buffer,0,len)写入目标文件
第二次循环:将(1500-1024)个字节通过in.read(buffer)读取至buffer中,len=76
将原来的76个字节覆盖。
通过再通过out.write(buffer,0,len)写入目标文件
第三次循环:读到文件末尾,len = -1。退出循环
3、释放资源:io操作一定要关流。
close( )
将close放在finally代码中执行。finally不是必须跟catch搭配使用
由于每个io操作都要关流,可以将关流写一个工具类(私有构造函数,所有的方法都是public static)。
4、常用的方法:
(1)InputStream
int read() 从流中读取一个字节。
不管读到的字节(8位)是多少,在转为int型的时候都在高24补24个0。
因此只要没读到末尾,返回的都是正数。
int read(byte[] buffer)
返回int不返回byte的原因:
如果返回是byte,文件中会有字节是等于-1,无法判断是否读到文件末尾
返回int:11111111 ---> 00000000 00000000 00000000 11111111
(2)OutputStream
void write(int ch) 为读写方便,读到int值,写入int值。将int值传入后,jvm会将int值强转为byte值,砍掉高24位
void write(byte[] buffer, 0, lenth);
所有的文件头几个字节都是特征码。所以将文件分割成多个文件后,只有第一个文件可以预览。
-----------