什么是直接内存
直接内存就是指:java堆外内存。
直接内存不是虚拟机运行时数据区的一部分,也不是Java虚拟机规范中定义的内存区域。
直接内存的分配不会受到java堆大小的限制,但是既然是内存,则肯定还是会受到本机总内存的大小及处理器寻址空间的限制。
服务器管理员配置虚拟机参数时,一般会根据实际内存设置-Xmx等参数信息,但经常会忽略掉直接内存,使得各个内存区域的总和大于物理内存限制。(包括物理上和操作系统级的限制),从而导致动态扩展时出现OOM。直接内存的作用
为了能直接分配和释放内存,在一些场景中显著提高性能,避免了Java堆和native堆中来回复制数据。如何访问直接内存
JDK1.4中加入了NIO类,引入一种基于通道(Channel)与缓冲区(Buffer)的I/O方式,它可以使用native函数库直接分配堆外内存,然后通过一个存储在java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作
直接内存
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 本文主要讲对象相关(对象实例化、内存布局、访问定位)和直接内存相关的内容。 目录 1 对象的实例化内存布局与访问定...