IO流

流就是一连串数据,流和数组都可以存储数据,但是数据一旦确定长度就不可变,而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();
			}
			
		}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值