8.2 运行时栈帧结构
8.2.1 局部变量表
代码清单8-1,局部变量表Slot复用对垃圾收集的影响之一
package cn.chapter8;
/*
* 代码清单8-1,局部变量表Slot复用对垃圾收集的影响之一
* VM Args: -verbose:gc
*/
public class Solution8_1 {
public static void main(String[] args) {
byte [] placeholder = new byte[64 *1024 *1024];
System.gc();
}
}
运行结果:
[GC 610K->373K(15872K), 0.0007834 secs]
[Full GC 373K->372K(15872K), 0.0019143 secs]
[Full GC 66087K->65908K(81476K), 0.0019888 secs]
代码清单8-2.局部变量表Slot复用丢垃圾收集的影响之一
package cn.chapter8;
/*
* 代码清单8-2.局部变量表Slot复用丢垃圾收集的影响之一
* VM Args: -verbose:gc
*/
public class Solution8_2 {
public static void main(String[] args) {
{
byte [] placeholder = new byte[64* 1024*1024];
}
System.gc();
}
}
运行结果:
[GC 610K->373K(15872K), 0.0013290 secs]
[Full GC 373K->372K(15872K), 0.0031922 secs]
[Full GC 66087K->65908K(81476K), 0.0019476 secs]
代码清单8-3.局部变量表Slot复用丢垃圾收集的影响之一
package cn.chapter8;
/*
* 代码清单8-3.局部变量表Slot复用丢垃圾收集的影响之一
* VM Args: -verbose:gc
*/
public class Solution8_3 {
public static void main(String[] args) {
{
byte [] placeholder = new byte[64* 1024*1024];
}
int a = 0;
System.gc();
}
}
运行结果:
[GC 610K->373K(15872K), 0.0007994 secs]
[Full GC 373K->372K(15872K), 0.0024169 secs]
[Full GC 66087K->372K(81476K), 0.0021021 secs]
这个修改看起来很莫名其妙,但运行程序却发现这次内存真的被正确回收了
程序清单8-4,未赋值的局部变量
//代码8-4,未赋值的局部变量
package cn.chapter8;
public class Solution8_4 {
public static void main(String[] args) {
int a;
System.out.println(a);
}
}