Java方法执行时内存的变换
用下面代码举例:
public class MethodTest08 {
// 主方法, 入口
public static void main(String[] args) {
System.out.println("main begin");
int x = 100;
m1(x);
System.out.println("main over");
}
public static void m1(int i){
System.out.println("m1 begin");
m2(i);
System.out.println("m1 over");
}
public static void m2(int i){
System.out.println("m2 begin");
m3(i);
System.out.println("m2 over");
}
public static void m3(int i){
System.out.println("m3 begin");
System.out.println(i);
System.out.println("m3 over");
}
}
从上述代码可以看得出来,主方法中先调用m1方法,m1方法再调用m2方法,m2方法再调用m3方法,m3方法再输出i.
再理解Java方法执行时内存的变换前需要先了解JVM主要的三块内存空间:(具体解释看图中的文字)
上述举例代码翻译成JVM内存图为:
在代码执行方法时,类加载器会最先将硬盘上的MethodTest08.class字节码文件加载到JVM的方法区(也就是将java代码加载到方法区),由于最先执行的是主函数,故会最先将主函数压入栈区,同时局部变量x也会被压入栈;接着主函数中调用了m1()方法,则m1()方法也被压入栈中,同时m1方法的参数也被压入栈中然后以此类推,直到最后应该方法m3()执行结束,输出100,则开始从m3()出栈直到main()出栈!程序执行结束,内存释放。
note:
int a = 100;
int b = a;
这个赋值原理是: 将a变量中保存的100这个数字复制一份传给b变量.
所以a和b是两个不同的内存空间,是两个局部变量.