1、nio说明 和 对比bio

nio和bio的区别

bio:

  1. 面向流的。
  2. 单向的。
  3. 阻塞的,这也是b这个的由来。

nio:

  1. 面向块的。(buffer)
  2. 双向的。
  3. 非阻塞的。同步的编程方式。是一种select模型

 

nio编程的常规步骤

从channel中获取的任何数据,都必须经过buffer来存放。

  1. 获取到channel。这里如果是从流中获取的channel,那么channel,也只支持单向。
  2. 构建Buffer
  3. 数据塞到Buffer中,如果是写回操作,执行flip
  4. 写回或读取

Buffer 的使用

  buffer中的3个核心变量,和一个不常用的变量(mark):

  1. mark 设置标记,记下position的位置 ,用reset方法,可以返回这
  2. posotion 读写的位置,下一个要读和写的位置。
  3. limit 可读或可写的最大值,下一个不可读或不可写的元素下标。
  4. capacity buffer的最大值,创建之后就不会变。

 、

直接内存映射,零拷贝:

常规的java流操作过程:

  1. 将数据从jvm中,拷贝到堆外内存,jvm中,仅保存地址。
  2. 修改堆外的数据块,写入,读取。
  3. 将堆外内存,变化的,再拷回jvm的内存中。

 buffer有一个直接内存映射的buffer,叫DirectByteBuffer,通过DirectByteBuffer可以将数据库块直接放在jvm堆外的内存中,使得操作数据时,不需要将内存数据,从jvm中拷贝到堆外内存中。

 可以通过调用buffer的map方法,获得一个内存中的buffer。直接操作buffer,相当于操作原文件。

转载于:https://www.cnblogs.com/amibandoufu/p/11441528.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值