Java编程的逻辑阅读总结(四)

栈是一块内存,但它的使用有特殊的约定,一般是先进后出的,往其中存放数据称为入栈,取出数据称为出栈,

最下面为栈底最上面为栈顶,栈一般从高位地址向低位地址扩展,栈底的地址是最高的相反栈顶是最低的

计算机系统主要使用栈来存放函数调用过程中需要的数据,参数,反回的地址以及函数中定义的局部变量。在函数被调用时这些内存被分配,在调用结束时这些内存就被释放了

返回值不太一样,它可能在栈中存放这些数据,有的系统使用系统内的存储器存储返回值

栈的空间是有限的函数每一次的调用,其参数,局部变量,返回地址等都会占用栈的控件,所以如果当递归调用时如果递归的深度过于深的情况下就会出现 java.lang.StackOverFlowError ,栈空间溢出。

对于数组和对象类型通常用两块内存去存储,一块存放实际的内容,一块存放内容的地址。实际内容(对象等)是在堆上创建的。在堆中分配的内存,由Java虚拟机的自动垃圾回收器来管理。

例如定义

public class Test {
    public static void main(String[] args) {
        Car car = new Car();
    }
}

class Car{
     String name;
     Double price;
}

执行这段代码,main方法压栈,在栈中先会存在main方法的参数 args

 Car car = new Car();

new Car() 返回的这个对象会在堆中开辟一片空间,会将返回的地址给car这个引用。

car这个引用则保存在栈中

如图:

栈与堆

想一起交流的朋友可以关注我的公众号,里面有群聊连接,每天会同步更新
博客连接 : AshinLee’s blog

这里写图片描述

©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页