JAVA的垃圾回收机制Garbage Collection (GC)是其与C/C++的主要区别之一。
程序员不需要编写内存回收和垃圾清理的代码,这些都将由JVM (HotSpot) 自动完成。
具体的说,GC机制对JVM中的内存进行标识,根据一定的回收策略自动回收内存,以保证JVM的内存空间。
1、JAVA的内存
(1)程序计数器 Program Counter Register
每一个线程有一个程序计数器,用来统计当前线程运行到第几行,是线程私有的。
(2)虚拟机栈 JVM Stack
每一个线程都有一个虚拟机栈,JVM栈线程私有。
线程中的每一个方法都会有一个栈帧,当方法被调用时,栈帧入虚拟机栈,方法执行完后,栈帧出虚拟机栈。
栈帧中存储着局部变量表、操作站、动态链接和方法出口等。
(3)本地方法栈 Native Method Stack
本地方法栈和虚拟机栈的区别:虚拟机栈执行java方法,本地方法栈执行native方法。
JDK7中的虚拟机是HotSpot ,它将虚拟机栈和本地方法栈放在一起使用。
(4) 堆区 Heap
JVM管理的内存中,堆区是最大的,也是最重要的。
堆区是所有线程共享的。
堆区的存在是为了存放对象实例。
堆内存需要在逻辑上是连续的,物理上可以不是。
(5)方法区 Method Area
可以将方法区作为堆的一个逻辑部分看待。
方法区也是线程共有的。
方法区存储的是已经被虚拟机加载的类的信息、final常量、静态变量和编译器即时编译的代码等。