Java_JVM参数-XX:MaxDirectMemorySize 与 两种 ByteBuffer: heap,direct ByteBuffer
来源:互联网 发布:江苏清华紫光软件集团 编辑:程序博客网 时间:2024/05/16 02:29
ByteBuffer有两种:
heap ByteBuffer -> -XX:Xmx
1.一种是heap ByteBuffer,该类对象分配在JVM的堆内存里面,直接由Java虚拟机负责垃圾回收,
direct ByteBuffer -> -XX:MaxDirectMemorySize
2.一种是direct ByteBuffer是通过jni在虚拟机外内存中分配的。通过jmap无法查看该快内存的使用情况。只能通过top来看它的内存使用情况。
JVM堆内存大小可以通过-Xmx来设置,同样的direct ByteBuffer可以通过-XX:MaxDirectMemorySize来设置,此参数的含义是当Direct ByteBuffer分配的堆外内存到达指定大小后,即触发Full GC。注意该值是有上限的,默认是64M,最大为sun.misc.VM.maxDirectMemory(),在程序中中可以获得-XX:MaxDirectMemorySize的设置的值。
import java.lang.reflect.Field;import java.nio.ByteBuffer;public class MaxDirectMemorySize { public static void main(String[] args) throws ClassNotFoundException, NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException { System.out.println("maxMemoryValue:"+sun.misc.VM.maxDirectMemory()); System.out.println("================================"); ByteBuffer buffer=ByteBuffer.allocateDirect(0); Class<?> c = Class.forName("java.nio.Bits"); Field maxMemory = c.getDeclaredField("maxMemory"); maxMemory.setAccessible(true); synchronized (c) { Long maxMemoryValue = (Long)maxMemory.get(null); System.out.println("maxMemoryValue:"+maxMemoryValue); } }}
下面要谈到垃圾回收机制:direct ByteBuffer通过full gc来回收内存的,direct ByteBuffer会自己检测情况而调用system.gc(),但是如果参数中使用了DisableExplicitGC那么就无法回收该快内存了,-XX:+DisableExplicitGC标志自动将System.gc()调用转换成一个空操作,就是应用中调用System.gc()会变成一个空操作。那么如果设置了就需要我们手动来回收内存了
@Test public void testAllocateDirector() throws Exception{ ByteBuffer buffer=ByteBuffer.allocateDirect(1024); Field cleanerField = buffer.getClass().getDeclaredField("cleaner"); cleanerField.setAccessible(true); Cleaner cleaner = (Cleaner) cleanerField.get(buffer); cleaner.clean(); }
那么除了FULL GC还有别的能回收direct ByteBuffer吗?CMS GC会回收Direct ByteBuffer的内存,CMS主要是针对old space空间的垃圾回收。但是是Oracle JDK 6u32以后的版本
讲了这么多谈下使用场景
1:多用于网络编程中,实现zero copy,数据不需要再native memory和jvm memory中来回copy
2:由于构造和析构Direct Buffer时间成本高,建议使用缓冲池,参见netty的实现
- Java_JVM参数-XX:MaxDirectMemorySize 与 两种 ByteBuffer: heap,direct ByteBuffer
- Java_JVM参数-XX:MaxDirectMemorySize 与 两种 ByteBuffer: heap,direct ByteBuffer
- 转载-Non-direct与direct ByteBuffer区别
- Non-direct与direct ByteBuffer区别
- DisableExplicitGC和Direct ByteBuffer
- DisableExplicitGC和Direct ByteBuffer
- DisableExplicitGC和Direct ByteBuffer
- DisableExplicitGC和Direct ByteBuffer
- Direct vs non-direct ByteBuffer
- Direct vs non-direct ByteBuffer
- Direct vs non-direct ByteBuffer
- Direct or Non-direct ByteBuffer
- ByteBuffer
- ByteBuffer
- ByteBuffer
- ByteBuffer
- ByteBuffer
- ByteBuffer
- swift_009(Swift 类型别名/安全/推断)
- Springboot 之 POI导出Word文件
- Java类加载器
- 谈我对网络协议的理解过程:
- Redis 订阅功能实现
- Java_JVM参数-XX:MaxDirectMemorySize 与 两种 ByteBuffer: heap,direct ByteBuffer
- Linux与Windows的文件共享
- 基于centos6的Hadoop2.6.5准备与安装
- nginx+tomcat+memcached负载均衡集群搭建(一)
- 伪装类
- 栈的压入弹出序列
- LeetCode 343. Integer Break 题解
- 线性代数相关概念
- BZOJ 4320 ShangHai2006 Homework