前言:
小编是一个刚刚入门的小菜鸟,初见面这两个兄弟,一下子不知索然,,,不用怕,自己动手查查就一清二白了,米老师经常说的,不怕不知道就怕不知道,无论什么时候,学习是永无止境的,知识是永无止境的!下面咱们一起来看看栈和堆这两个兄弟吧!
正文:
一、总说
程序运行时,它的数据必须存储在内存中。栈和堆的作用就来了,运行中的程序使用这两个内存区域来存储数据。
二、栈
1、含义:
栈是一个内存数组,是一个LIFO(last-in first-out,后进先出)的数据结构。这个在下面的举例中更加清楚的有所了解。
2、存储数据类型
3、特征
数据只能从栈的顶端插入和删除。
解释:入栈:把数据放到栈顶
出栈:从栈顶删除数据
栈顶:一个栈分为空闲的数据内存和存储数据的内存,存储数据的内存如果从底部依次向上为100,200,则200的上部为栈顶,向栈顶放入一个300,则300的上部为栈顶。
如图所示:
二、堆
1、含义
堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据。
2、特点
存放引用类型
3、垃圾收集过程
三、区别
四、注意问题
在用到栈和堆的过程中,都要防止越界现象的发生。
总结:
刚刚接触这个概念,理解的不是很深刻,有什么错误欢迎大家给我指正,在以后的学习中,会继续学习的!学习不是一次性的过程,继续学习中。