-
什么是直接内存
直接内存就是指:java堆外内存。
直接内存不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域。
直接内存的分配不会受到java堆大小的限制,但是既然是内存,则肯定还是会受到本机总内存的大小及处理器寻址空间的限制。
服务器管理员配置虚拟机参数时,一般会根据实际内存设置-Xmx等参数信息,但经常会忽略掉直接内存,使得各个内存区域的总和大于物理内存限制。(包括物理上和操作系统级的限制),从而导致动态扩展时出现OOM。 -
直接内存的作用
为了能直接分配和释放内存,在一些场景中显著提高性能,避免了Java堆和native堆中来回复制数据。 -
如何访问直接内存
JDK1.4中加入了NIO类,引入一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用native函数库直接分配堆外内存,然后通过一个存储在java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作
网友评论