堆(Heap)和栈(Stack)是平时编程接触比较多的两个计算机语言,网上相关介绍内容已经有很多了,作者在此记录下我的理解,也供以后温故之用。
1. 栈(Stack)和堆(Heap)的定义
栈:空间小,速度快,放对象的引用;一个先进后出(Last In First Out )的数据结构,通常用于保存基本类型、字面量、对象的引用变量、自定义变量。
堆:空间大,可动态申请,放所有创建的对象;一个可动态申请的内存空间,通常用于保存关键字new 构造出来的对象,malloc(C/C++)语句所产生的内存空间、数组
以上定义回答了堆(Heap)和栈(Stack)是什么,以及它们主要用来干什么(保存什么的),有一个共同点:都是java运行时内存中(RAM)存放数据的地方。
2. 各自存放数据的特点
栈:当java中定义一个变量时,就会在栈内存中分配,当运行到超过变量的作用域时,java会自动释放掉该变量所分配的内存空间,该内存空间会另作他用(生命周期)。
堆:在堆中分配的内存,不同语言处理方式不完全相同,java中由虚拟机的自动回收器来管理,当没有指向该对象的引用时,垃圾回收机制在适当的时候回收掉。
当对象被创建放入堆时,此时有一个栈中的特殊引用变量指向该对象在内存中的首地址,而这个特殊变量被称为引用变量,在程序中要访问该对象时通过该引用变量进行访问!
以上是我的理解,一点一点深入学习中,欢迎指正!