NIO——(New IO,新IO)非阻塞式输入/输出流

1.NIO的介绍1.1由来     BufferedReader和InputStream从流中读取数据时,没有读到有效的数据,程序就会在此处阻塞该线程的执行。传统的输入流、输出流都是通过字节的移动来处理(即使不直接去处理字节流,但是底层的实现还是依赖于字节的处理),也就是说,面向流的输入输出系统都是一次只能处理一个字节,都会产生阻塞,因此面向流的输入输出系统通常效率不高。   jdk1...
摘要由CSDN通过智能技术生成

1.NIO的介绍

1.1由来

     BufferedReader和InputStream从流中读取数据时,没有读到有效的数据,程序就会在此处阻塞该线程的执行。传统的输入流、输出流都是通过字节的移动来处理(即使不直接去处理字节流,但是底层的实现还是依赖于字节的处理),也就是说,面向流的输入输出系统都是一次只能处理一个字节,都会产生阻塞,因此面向流的输入输出系统通常效率不高。

   jdk1.4开始,java提供了一系列改进的输入输出处理的新功能,这些功能被统称为新IO,新增了许多用于处理输入和输出的类,这些类都被放在了java.nio包的以及子包下,并且对源java.io包中的许多类都以NIO为基础进行改写,新增了满足NIO的功能。

  新IO和传统的IO的主要区别在处理输入和输出的方式上,新IO将文件或文件的一段区域映射到内存中,这样就可以像访问内存一样来访问文件了(这种方式模拟了操作系统上的虚拟内存的概念),这样处理的速度就会提升很多。

1.2新IO的核心对象

   Channel(通道):在新IO中所有的数据都需要通过通道传输,Channnel于传统的Inputstream、Outputstream最大的区别在于它提供了一个map()方法,通过该方法将“一块数据”映射到内存中,如果说传统的输入输出时面向流的处理,新IO则是面向块的处理。

   Buffer(缓冲):可以被理解成一个容器,其本质是一个数组,发送数据到channel或者是从channel中读取数据都要先让如buffer中。

   除了Channel和Buffer之外,新IO还提供了用于将

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值