在计算机领域,堆栈是一个不容忽视的概念。其实,堆栈其实是两种数据结构,是数据项按序排列的数据结构,只能在一端(称为栈顶(top))对数据项进行插入和删除。
在程序运行时,Java虚拟机会自动在内存中为变量和方法分配相应的区域,用来保存变量的值和方法的各种属性。对于某一个进程的内存空间而言,可以在逻辑上分为3个部分:代码区,静态数据区,动态数据区。动态数据区一般就是堆栈。下面介绍一下堆区和栈区:
栈区: 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
堆区(heap):是由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式链表。
在某个类中,实例变量一般存储在堆区,局部变量和方法存储在栈区。
这里介绍一下实例变量和局部变量:
实例变量是被声明在类而不是方法里面,它们代表每个独立对象的“字段”,每个实例变量具有不同的值。实例变量存在于所属的对象中。
局部变量和方法的参数都是被声明在方法中。它们是暂时的,且生命周期只限于方法被放在栈上的这段时间(也就是方法调用直至执行完毕为止)。
如果局部变量是个对象的引用,只有变量本身会在栈上,对象本身只会存在于堆上。
如我们建立对象Dog d=new Dog();那么变量d会存在栈上,而由new Dog()新建的对象会存放于堆上。