Java之IO温故知新

Java中的核心库java.io提供了全面的I/O接口,其中I/O指的是Input和Output,通过数据流、序列化和文件系统提供系统的输入和输出。
Java中的I/O是以流为基础实现输入/输出的。当程序需要读取数据时,就会开启一个通向数据源的流,这个数据源可以是文件、内存或网络连接;当程序需要写入数据时,就会开启一个通向目的地的流,这个目的地也可以是文件、内存或网络连接。
I/O流按照流的方向分为:

  • 输入流:以外部输入设备作为参照物,当程序从外部输入设备(文件、网络等)读取数据时,流的方向是从外部输入设备到运行程序,这种方向的流为输入流;
  • 输出流;以外部输入设备作为参照物,当程序把数据写入外部输入设备(文件、网络等)时,流的方向是从运行程序到外部输入设备,这种方向的流为输出流;

Java中的I/O流的作用是传输数据。数据的最小单位是比特(bit),比特是计算机中最基本的存储单元,二进制中的一位就是1 bit。数据的基本单位是字节(Byte),一个Byte是一个8bit的数据单位,换算关系为1 Byte = 8 bit。通常Byte简写为B,所以也经常使用KB、MB、GB等标识数据容量。除了使用字节作为传输单位,还可以使用字符作为传输单位。字符(Char)是计算机中使用的字母、数字、字和符号,如A,b,2,你,#等。一般情况下,一个英文字符占用1字节,一个汉字字符占用2字节,但在不同的编码方式下,占用的字节数是不一定的。
I/O流按照数据传输的单位分为:

  • 字节流;
  • 字符流;

在I/O流中,传输的数据类型是字节(Byte)就是字节流,传输的数据类型是字符(Char)就是字符流。程序中操作的类型是读取就是输入流,程序中操作的类型是写入就是输出流。在Java中操作字节类型的类是InputStream/OutputStream的子类,操作字符类型的类是Reader/Writer的子类,具体如下:

I/O流分类字节流字符流
输入流InputStreamReader
输出流OutputStreamWriter

在Java的I/O体系中,除了上面4中类之外,还有一组字节流/字符流的转换类。
OutputStreamWriter类示例(字符转字节)

public static void main(String[] args)throw IOException {
	File f = new File("test.txt");
	OutputStreamWriter osw = new OutputStreamWriter (new FileOutputStream(f),"UTF-8");
	osw.write("字符转字节");
	osw.close();
}

InputStreamReader类示例(字节转字符)

public static void main(String[] args)throw IOException {
	File f = new File("test.txt");
	InputStreamReader isr = new InputStreamReader (new FileOutputStream(f),"UTF-8");
	char[] buf = new char[1024];
	int len = isr.read(buf);
	System.out.println(new String(buf,0,len));
	isr.close();
}

在I/O体系中,通常会遇到同步/异步,堵塞/非堵塞,当I/O操作发生时,一定是有两方参与的,分别是调用方和被调用方,堵塞/非堵塞描述的是调用方,同步/异步描述的是被调用方。场景描述上面4个概念:
A调用B

  • 若是堵塞,那么A在发出调用命令后,要一直等待B返回结果;
  • 若是非堵塞,那么A在发出调用命令后,不需要等待,可以去做自己的事情;
  • 若是同步,那么B在收到A的调用命令后,会立即执行要做的事情,A本次调用可以得到结果;
  • 若是非同步,那么B在收到A的调用命令后,不保证会立即执行要做的事情,但是保证会做,B在做好了之后会通知A;

同步/异步与堵塞/非堵塞描述的是不同对象,同步不一定堵塞,异步也不一定非堵塞,场景描述:
老张烧水

  • 老张把普通水壶放到火炉上,一直在水壶旁边等着水烧开(同步堵塞);
  • 老张把普通水壶放到火炉上,去客厅看电视,时不时去看一下水有没有烧开(同步非堵塞);
  • 老张把响水壶放到火炉上,一直在水壶旁边等着水烧开(异步堵塞);
  • 老张把响水壶放到火炉上,去客厅看电视,水壶响之前不去看,响了再去看水壶(异步非堵塞);

这时Java中的I/O分为3种:

  • BIO:同步堵塞I/O;
  • NIO:同步非堵塞I/O;
  • AIO:异步非堵塞I/O;

BIO,Blocking I/O,一种同步堵塞I/O模型,数据的读取和写入必须堵塞在一个线程内等待其完成。适用于连接数较小且固定的场景,对服务器资源要求较高。
NIO,New I/O,支持同步非堵塞I/O模型,适用于连接数较多且连接比较短的场景,如聊天服务器。
AIO,Asynchronous I/O,异步非堵塞I/O模型,适用于连接数多且连接比较长的场景,如相册服务器。

学习《深入理解Java核心技术》图书后的总结分享。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值