3、直接内存

1. 直接内存介绍

直接内存(Direct Memory)并不是虚拟机运行时数据一部分,也不是《Java 虚拟机规范》中定义的内存区域。如果这部分内存被频繁使用,也会导致OOM。

在JDK4中新引入的NIO(New Input/Output)类,其引入了一种基于通道(Channel)与缓冲区(Buffer)的方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作。这在一些场景中可以显著提高性能,避免了java堆和Native堆来回copyt数据。

直接内存的分配不受Java堆大小限制,受本机总内存大小限制。

如下图所示,没有直接内存时,应用程序访问磁盘中数据时需要由用户态切换到内核态,即应用程序先与JVM交互,然后JVM在与直接内存交互。
在这里插入图片描述
如下图所示,当使用直接内存后,不在需要数据从用户态copy到内核态了,应用程序可以直接访问物理内存。
在这里插入图片描述

2.直接内存使用

直接内存大小可以通过MaxDirectMemorySize设置。例如设置-XX:MaxDirectMemorySize=50M
如下代码所示为直接内存使用,bytes为存放字节的数组,可以是从文件中 读取的内容等,byteBuffer为分配的50M直接内存,假设读取大文件就可以放到bytes数组中,然后把数组内容直接写到直接内存中。

public class Demo1 {
    public static int length = 1024*1024*50;    //50M

    public static void main(String[] args) {
        byte[] bytes = new byte[1024*1024*10];
        ByteBuffer byteBuffer = ByteBuffer.allocate(length);
        byteBuffer.put(bytes);	//把bytes放入到直接内存中
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值