转自:https://blog.csdn.net/weixin_41925938/article/details/81202193
堆和栈:程序运行时的内存区域
我们把内存分为堆空间和栈空间。
栈空间比较小,但是读取速度快
堆空间比较大,但是读取速度慢
1.栈
栈的特征:
数据只能从栈的顶端插入和删除
把数据放入栈顶称为入栈(push)
从栈顶删除数据称为出栈(pop)
简单地说:先进后出
2.堆
堆是一块内存区域,与栈不同,堆里的内存能够以任意顺序存入和移除
3.值类型和引用类型
类型被分为两种:值类型(整数,bool struct char 小数)和引用类型(string 数组 自定义的类,内置的类)。
1)值类型只需要一段单独的内存,用于存储实际的数据,(单独定义的时候放在栈中)
2)引用类型需要两段内存
第一段存储实际的数据,它总是位于堆中
第二段是一个引用,指向数据在堆中的存放位置
注意: 但我们使用引用类型赋值时,其实是赋值的引用类型的引用,如果数组是一个值类型的数组,那么数组中直接存储值,如果是一个引用类型的数组(数组中存储的是引用类型),那么数组中存储的是引用(内存地址)。