Java中nio与buffer

1 disk->disk controller->DMA(direct memory access)->kernel space buffer -> user space buffer
从kernel到user space的拷贝非常浪费了。


2 内存映射可以减少这种浪费。
a)减少了read() write()等系统调用。
b)减少了buffer间的拷贝


3 MMU(Memory management unit)来管理虚拟内存的映射。


4 file lock(文件锁)。读写锁,读锁可以并发,写锁只能独占。

5 硬盘的读是block io,tty console及网络则是stream io。stream(流)一般慢于block(块)。

6 nio中,Buffer的compact:将pos及数据移到0

7 Direct Buffer : 连续的地址空间,而jvm 的byte array并不一定是连续的。需由native方法实现,ByteBuffer.allocateDirect()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值