流就是一连串数据,流和数组都可以存储数据,但是数据一旦确定长度就不可变,而IO流就不会这样,存储不会受到限制
分类:
方向划分:输入输出流
操作单元:字节字符流
功能:节点流包装流
InputStream 输入流
OutputStream 输出流
字节流(万能流)因为文件存储都是以字节为单位
InputStream---FileInputStream
OutputStream--FileOutputStream---flush
close关闭流
字符输入流 Reader 抽象类 FileReader 文件字符输入流
流向:输入流 功能:节点流 操作单元:字符流
字符输出流: Writer 抽象类 FileWriter 文件字符输出流
流向:输出流 操作单元:字符流 功能:节点流
节点流:直接从数据源到目的地
处理流(包装流):在中间进行包装,增强一些功能
转换流(节点流)把字节流转换成字符流
InputStreamReader ---Reader字节输入转换流
OutputStreamWriter --Writer 字节输出转换流
Data流(节点流)DataInputStream DataOutputStream 可以读写基本类型和String类型,读写顺序得一致
字符缓冲流
字符输入 缓冲流 BufferedReader 功能:功能流 流向:输入流 操作单元:字符流
新增方法:String readLine() 读取一个文本行。
字符输出缓冲流 BufferedWriter
新增方法: void newLine() 写入一个行分隔符。
纯在新增方法,不能多态使用
对象流: 保留数据+数据类型
对象流(节点流)
序列化:如果想要把对象的信息状态,变为可存储|可传输的过程
序列化输出流 ObjectOutputStream(OutputStream)
新增方法: void writeObject(Object obj) 将指定的对象写入 ObjectOutputStream。
反序列化输入流 ObjectInputStream(InputStream)
1.不是所有类型的对象都能序列化 实现java.io.Serializable
2.先序列化后反序列化 写出读入的过程一致
3.不是对象的所有属性都需要序列化 transient
4.static不能被序列化
5.如果父类实现了Serializable接口,子类中所有内容都能序列化
6.如果父类没有实现,子类实现了Serializable接口,只能序列化子类中独有的内容
InputStream is=null;
OutputStream os=null;
try {
is=new FileInputStream("D:/Kugou/Temp/5.txt");
os=new FileOutputStream("D:/t.txt");
byte []arr=new byte[1024];
int len=0;
while((len=is.read(arr))!=-1){
os.write(arr, 0, len);
os.flush();
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
finally {
try {
if(is!=null){
is.close();
}
if(os!=null){
os.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}