20170715 NIO

参考文献:《Java疯狂讲义》(第三版)

新IO和传统的IO有相同的目的,都是用于进行输入/输出,但使用了不同的方式来处理。

新IO采用内存映射文件的方式来处理,将文件或者文件的一段区域映射到内存中,这样就可以像访问内存一样访问文件了。

Channel(通道)和Buffer(缓冲)是新IO中的两个核心对象,Channel是对出传统IO系统的模拟,在NIO系统中所有的数据都需要通过通道传输;Channel与传统的InputStream、OutputStream最大的区别在于它提供了一个map()方法,通过map()方法可以将一块数据映射到内存中。

Buffer可以理解成一个容器,它的本质是一个数组,发送到Channel中的所有对象都必须首先放到Buffer中,而从Channel中的读取的数据亦复如是。

Channel与传统流对象的区别

1、Channel可以直接将指定文件的部份或全部直接映射成Buffer

2、程序不能直接访问Channel中的数据,包括读写,Channel只能与Buffer进行交互:数据——>Channel——>Buffer——>程序

3、它有一个map()方法,通过该方法可以直接将一块数据映射到内存中。

如果说传统的IO是面向流的处理,NIO则是面向块的处理。

Buffer的主要作用是装入数据,然后输出数据。

通过allocate()方法创建的Buffer对象是普通Buffer,allocateDirect()方法创建直接Buffer

直接Buffer创建成本高,但是读取效率高

直接Buffer创建成本高,所以直接Buffer只适用于长期生存的Buffer,而不是是短期生存、一次用完就丢弃的Buffer

文件锁虽然可以用于控制并发访问,但对于高并发访问的情形,还是推荐使用数据库,而非文件

NIO2

Java7引入Path接口与Files、Paths工具类

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java I...
    JackChen1024阅读 7,587评论 1 143
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,372评论 11 349
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,981评论 19 139
  • 转自 http://www.ibm.com/developerworks/cn/education/java/j-...
    抓兔子的猫阅读 2,352评论 0 22
  • 过滸墅, 吴王陵顶秃。 当年长袖响屐舞, 争霸烟尘入黄土。 姑苏斜阳暮。
    陽春阅读 149评论 0 1