Java程序启动后作为一个进程运行在操作系统中,那么这个进程有哪些部分需要分配内存?
1 Java堆
Java堆用于存储Java对象,堆的大小在JVM启动时向操作系统一次性申请完成,通过-Xmx和-Xms来控制大小。其中,Xmx表示堆的最大值,Xms表示堆的初始值。一旦分配完成,堆的大小就固定了,不能在内存不够时再向操作系统重新申请,同时当内存空闲时也不能将多余的空间交还给操作系统。
2 线程
JVM运行实际程序的实体是线程,而线程需要内存来存储数据。每个线程创建时JVM都会为它创建一个堆栈,堆栈的大小因JVM实现的不同而不同。
3 类和类加载器
类和类加载器存储在堆中,该区域称为永久代(PermGen区)。JVM按需加载类,只会加载一个类到内存一次。
4 NIO
jdk1.4以后引入了基于通道和缓冲区执行I/O的新方式NIO,使用java.nio.ByteBuffer.allocateDirect()方法分配本机内存而不是Java堆上的内存。
5 JNI
JNI使本机代码(如C语言程序)可以调用Java方法。实际上,Java运行时本身依赖JNI来实现类库功能,所以JNI会增加Java运行时的本机内存占用量。
参考资料
《深入分析Java Web技术内幕》 P201-203