Jvm之直接内存与非直接内存

直接内存

  • 直接内存:概指系统内存,而非堆内存,不指定大小时它的大小默认与堆的最大值-Xmx参数值一致。

  • 非直接内存: 也可以称之为堆内存,运行JVM都会预先分配一定内存,我们把JVM管理的这些内存称为堆内存(非操作系统直接内存),JVM会对这些内存空间的分配和回收进行管理。

所谓 直接的关系指的是与底层操作系统的关系。

直接 非直接内存的概念与NIO有非常大的关联;

  1. 在NIO之前,java.io 的方式是:

     磁盘IO --> 直接内存[系统内核态] -->   非直接(堆)内存[用户态]  -->  直接内存[系统内核态] --> 磁盘IO
    
  2. 而NIO中,对文件的读写不再跟堆内存关联

     磁盘IO --> 系统直接内存 --> 磁盘IO
    

读写文件时可以直接申请堆外内存。

优点

  • 避免内核态和用户态之间反复切换,实现文件的高效存取;

  • 非JVM管理内存,能减少GC时造成的STW(stop the world)操作。

缺点

内存管理的成本增加,由于没有自动回收机制的管理,使用不当可能造成内存溢出。

直接内存的使用

我们知道直接内存直接使用操作系统内存,避免了反复的拷贝。

直接内存的使用通过:allocateDirect创建,需要注意的时,直接内存的申请成本比申请普通堆内存更大;

基于以上特性,直接内存在文件较大时会有不错的表现,由于申请开销问题,当操作海量的小文件时我们就需要慎重考虑是否使用直接内存了,此时还会带来内存碎片化的问题。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值