Java IO流学习总结一:输入输出流[通俗易懂]

Java IO流学习总结一:输入输出流[通俗易懂]JavaIO流学习总结一:输入输出流转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/53761199本文出自【赵彦军的博客】Java流类图结构:流的概念和作用流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象。即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直

大家好,又见面了,我是你们的朋友全栈君。

Java IO流学习总结一:输入输出流

转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/54292148
本文出自【赵彦军的博客】

Java IO流学习总结一:输入输出流
Java IO流学习总结二:File
Java IO流学习总结三:缓冲流-BufferedInputStream、BufferedOutputStream
Java IO流学习总结四:缓冲流-BufferedReader、BufferedWriter
Java IO流学习总结五:转换流-InputStreamReader、OutputStreamWriter
Java IO流学习总结六:ByteArrayInputStream、ByteArrayOutputStream
Java IO流学习总结七:Commons IO 2.5-FileUtils

2021年 Java Okio-更加高效易用的IO库

Java流类图结构:

这里写图片描述

流的概念和作用

流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象。即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直观的进行数据操作。

IO流的分类

  • 根据处理数据类型的不同分为:字符流和字节流
  • 根据数据流向不同分为:输入流和输出流

字符流和字节流

字符流的由来: 因为数据编码的不同,而有了对字符进行高效操作的流对象。本质其实就是基于字节流读取时,去查了指定的码表。 字节流和字符流的区别:

  • 读写单位不同:字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节。

  • 处理对象不同:字节流能处理所有类型的数据(如图片、avi等),而字符流只能处理字符类型的数据。

  • 字节流:一次读入或读出是8位二进制。

  • 字符流:一次读入或读出是16位二进制。

设备上的数据无论是图片或者视频,文字,它们都以二进制存储的。二进制的最终都是以一个8位为数据单元进行体现,所以计算机中的最小数据单元就是字节。意味着,字节流可以处理设备上的所有数据,所以字节流一样可以处理字符数据。

结论:只要是处理纯文本数据,就优先考虑使用字符流。 除此之外都使用字节流。

输入流和输出流

输入流只能进行读操作,输出流只能进行写操作,程序中需要根据待传输数据的不同特性而使用不同的流。

输入字节流 InputStream

  • InputStream 是所有的输入字节流的父类,它是一个抽象类。
  • ByteArrayInputStreamStringBufferInputStreamFileInputStream 是三种基本的介质流,它们分别从Byte 数组StringBuffer、和本地文件中读取数据。
  • PipedInputStream 是从与其它线程共用的管道中读取数据,与Piped 相关的知识后续单独介绍。
  • ObjectInputStream 和所有FilterInputStream 的子类都是装饰流(装饰器模式的主角)。

输出字节流 OutputStream

  • OutputStream 是所有的输出字节流的父类,它是一个抽象类。
  • ByteArrayOutputStreamFileOutputStream 是两种基本的介质流,它们分别向Byte 数组、和本地文件中写入数据。
  • PipedOutputStream 是向与其它线程共用的管道中写入数据。
  • ObjectOutputStream 和所有FilterOutputStream 的子类都是装饰流。

总结:

  • 输入流:InputStream或者Reader:从文件中读到程序中;
  • 输出流:OutputStream或者Writer:从程序中输出到文件中;

节点流

节点流:直接与数据源相连,读入或读出。
直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。
这里写图片描述

常用的节点流

  • 父 类 :InputStreamOutputStreamReaderWriter
  • 文 件 :FileInputStreamFileOutputStreanFileReaderFileWriter 文件进行处理的节点流
  • 数 组 :ByteArrayInputStreamByteArrayOutputStreamCharArrayReaderCharArrayWriter 对数组进行处理的节点流(对应的不再是文件,而是内存中的一个数组)
  • 字符串 :StringReaderStringWriter 对字符串进行处理的节点流
  • 管 道 :PipedInputStreamPipedOutputStreamPipedReaderPipedWriter 对管道进行处理的节点流

处理流

处理流和节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。如BufferedReader.处理流的构造方法总是要带一个其他的流对象做参数。一个流对象经过其他流的多次包装,称为流的链接。
这里写图片描述

常用的处理流

  • 缓冲流:BufferedInputStreanBufferedOutputStreamBufferedReaderBufferedWriter 增加缓冲功能,避免频繁读写硬盘。
  • 转换流:InputStreamReaderOutputStreamReader实现字节流和字符流之间的转换。
  • 数据流: DataInputStreamDataOutputStream 等-提供将基础数据类型写入到文件中,或者读取出来。

转换流

InputStreamReaderOutputStreamWriterInputStreamOutputStream作为参数,实现从字节流到字符流的转换。

构造函数

InputStreamReader(InputStream);        //通过构造函数初始化,使用的是本系统默认的编码表GBK。
InputStreamReader(InputStream,String charSet);   //通过该构造函数初始化,可以指定编码表。
OutputStreamWriter(OutputStream);      //通过该构造函数初始化,使用的是本系统默认的编码表GBK。
OutputStreamwriter(OutputStream,String charSet);   //通过该构造函数初始化,可以指定编码表。

实战演练

  • FileInputStream类的使用:读取文件内容
package com.app;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;

public class A1 { 
   

	public static void main(String[] args) { 
   
		A1 a1 = new A1();
	
		//电脑d盘中的abc.txt 文档
		String filePath = "D:/abc.txt" ;
		String reslut = a1.readFile( filePath ) ;
        System.out.println( reslut ); 
	}


	/** * 读取指定文件的内容 * @param filePath : 文件的路径 * @return 返回的结果 */
	public String readFile( String filePath ){ 
   
		FileInputStream fis=null;
		String result = "" ;
		try { 
   
			// 根据path路径实例化一个输入流的对象
			fis  = new FileInputStream( filePath );

			//2. 返回这个输入流中可以被读的剩下的bytes字节的估计值;
			int size =  fis.available() ;
			//3. 根据输入流中的字节数创建byte数组;
			byte[] array = new byte[size];
			//4.把数据读取到数组中;
			fis.read( array ) ; 

			//5.根据获取到的Byte数组新建一个字符串,然后输出;
			result = new String(array);	

		} catch (FileNotFoundException e) { 
   
			e.printStackTrace();
		}catch (IOException e) { 
   
			e.printStackTrace();
		}finally{ 
   
			if ( fis != null) { 
   
				try { 
   
					fis.close();
				} catch (IOException e) { 
   
					e.printStackTrace();
				}
			}
		}

		return result ;
	}


}


  • FileOutputStream 类的使用:将内容写入文件
package com.app;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class A2 { 
   

	public static void main(String[] args) { 
   
		A2 a2 = new A2();

		//电脑d盘中的abc.txt 文档
		String filePath = "D:/abc.txt" ;

		//要写入的内容
		String content = "今天是2017/1/9,天气很好" ;
		a2.writeFile( filePath , content  ) ;

	}

	/** * 根据文件路径创建输出流 * @param filePath : 文件的路径 * @param content : 需要写入的内容 */
	public void writeFile( String filePath , String content ){ 
   
		FileOutputStream fos = null ;
		try { 
   
			//1、根据文件路径创建输出流
			fos  = new FileOutputStream( filePath );

			//2、把string转换为byte数组;
			byte[] array = content.getBytes() ;
			//3、把byte数组输出;
			fos.write( array );

		} catch (FileNotFoundException e) { 
   
			e.printStackTrace();
		}catch (IOException e) { 
   
			e.printStackTrace();
		}finally{ 
   
			if ( fos != null) { 
   
				try { 
   
					fos.close();
				} catch (IOException e) { 
   
					e.printStackTrace();
				}
			}
		}
	}


}

注意:

  1. 在实际的项目中,所有的IO操作都应该放到子线程中操作,避免堵住主线程。
  2. FileInputStream在读取文件内容的时候,我们传入文件的路径("D:/abc.txt"), 如果这个路径下的文件不存在,那么在执行readFile()方法时会报FileNotFoundException异常。
  3. FileOutputStream在写入文件的时候,我们传入文件的路径("D:/abc.txt"), 如果这个路径下的文件不存在,那么在执行writeFile()方法时, 会默认给我们创建一个新的文件。还有重要的一点,不会报异常。

效果图:

这里写图片描述

  • 综合练习,实现复制文件,从D盘复制到E盘
package com.app;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

public class A3 { 
   

	public static void main(String[] args) { 
   
		A3 a2 = new A3();

		//电脑d盘中的cat.png 图片的路径
		String filePath1 = "D:/cat.png" ;

		//电脑e盘中的cat.png 图片的路径
		String filePath2 = "E:/cat.png" ;

		//复制文件
		a2.copyFile( filePath1 , filePath2 );

	}

	/** * 文件复制 * @param filePath_old : 需要复制文件的路径 * @param filePath_new : 复制文件存放的路径 */
	public void copyFile( String filePath_old  , String filePath_new){ 
   
		FileInputStream fis=null ;
		FileOutputStream fout = null ;
		try { 
   
			// 根据path路径实例化一个输入流的对象
			fis  = new FileInputStream( filePath_old );

			//2. 返回这个输入流中可以被读的剩下的bytes字节的估计值;
			int size =  fis.available() ;
			//3. 根据输入流中的字节数创建byte数组;
			byte[] array = new byte[size];
			//4.把数据读取到数组中;
			fis.read( array ) ; 

			//5、根据文件路径创建输出流
			fout = new FileOutputStream( filePath_new ) ;
			
			//5、把byte数组输出;
			fout.write( array );

		} catch (FileNotFoundException e) { 
   
			e.printStackTrace();
		}catch (IOException e) { 
   
			e.printStackTrace();
		}finally{ 
   
			if ( fis != null) { 
   
				try { 
   
					fis.close();
				} catch (IOException e) { 
   
					e.printStackTrace();
				}
			}
			if ( fout != null ) { 
   
				try { 
   
					fout.close();
				} catch (IOException e) { 
   
					e.printStackTrace();
				}	
			}
		}
	}
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/130104.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 【ztree系列】树节点的模糊查询

    【ztree系列】树节点的模糊查询以前设计模糊查询的功能,一般都是针对表格来做的,还真没考虑过对tree进行模糊查询,也可能是因为遇到的数据量还没到头疼的程度吧。为了完美的实现模糊查询的效果,搞了半天css,对输入框显示效果的设置更是修改了n多次,什么半圆角、边框、光影。。。真佩服我这颗屡试屡换的小心脏啊一、页面设计对于搜索功能,首先要有输入框,用于接收输入内容;然后就是显示搜索结果用的标签,控制焦点用的上移下动按钮。其实

  • EXACT函数_excel中的exact函数

    EXACT函数_excel中的exact函数EXACT函数:EXACT函数是一个文本函数,通过这个函数可以将不同的字符串进行对比,通常用于信息核对。EXACT函数的功能:比较两个字符串是否一致,返回不同的结果。EXACT函数的语法结构:EX

  • 微信小程序发送消息推送_小程序推送消息设置

    微信小程序发送消息推送_小程序推送消息设置在小程序开发中,如果想实现:用户发给小程序的消息以及开发者需要的事件推送,在小程序项目中,我们想要实现这样一个功能,比如我们小程序中的客服功能,我不想要使用小程序后台的在线客服功能,但我又想实现客服功能,这个时候微信提供了消息推送功能,在小程序后台的设置,开发设置中,消息推送功能:点击开启消息推送功能,认证成功进入到消息推送配置界面:这里配置几个参数注意一下:URL(服务器………

  • Matlab GUI界面设计

    Matlab GUI界面设计摘要:本篇博文基于MATLAB2014a进行GUI设计。

  • linux替换大文件内容,Linux批量替换文件内容

    linux替换大文件内容,Linux批量替换文件内容今天测试人员一不小心把导航的地址改错了,大约6000多个导航文件,要通过后台配置的话也很麻烦,可以通过linux命令实现对批量文件进行内容替换,但是技术经理不在,我对linux命令不熟,没办法只好硬着头皮来。经在网上一番辛苦搜索,找到以下几个命令,并尝试执行……最终终于实现效果,哎,“书到用时方恨少”,特此针对今天的情况总结了一下Linux批量替换文件内容的命令,第一种:格式:sed-i”s/…

  • 微服务中的日志管理 — ELK

    微服务中的日志管理 — ELK通过使用微服务,我们能够解决许多在单体应用中暴露的问题,并且它允许我们创建稳定的分布式应用程序,并对代码,团队规模,维护,发布周期,云计算等进行所需要的控制。但同时微服务也引入了一些挑战,例如分布式日志管理和查看。需要提供在众多服务中查看分布的完整事务日志和分布式调试的能力。实际上,挑战在于微服务是相互隔离的,它们不共享公共数据库和日志文件。随着微服务数量的增加以及我们使用自动化持续集成工具实现…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号