堆栈的初步理解

堆栈区本质没有区别,都是内存里的一块区域,区别在于用法

程序的运行伴随着函数的调用,函数内部就是我们的代码,里面有各种变量或者数据处理,装载这些变量或者说数据的就是内存。
当变量出现在函数后就会出现一个问题,那就是变量的使用范围或者生命周期仅仅是函数内部还是超越函数,如果一个变量仅仅在函数内部,那么当函数结束后,这个变量占据的内存就可以进行销毁了,这就是局部变量。

这个过程先来的反而后释放,因此局部变量占据的内存区域被称为栈区。栈区的内存管理无需程序员关心,实际上栈区是非常好管理的,栈区的内存申请和释放是非常有规律的,先来的后释放,遵循栈的顺序。

如果变量的生命周期超越了函数,那么当函数运行完成后,变量占据的内存是不可以回收的。那么什么时候可以回收呢,显然只有使用这块内存的程序员自己知道,也就是说 如果程序员不去释放内存,那么在任何函数中,都可以使用这块内存或者这个变量,这些变量占据的内存就是堆区。

堆区的申请和释放没有任何规律可言,不像栈区那有先来后释放的顺序

现在知晓了为什么要区分堆栈了,其实就是使用场景不一样。如果你的变量生命周期是局限在函数内部,这就是局部变量。如果你希望变量的生命周期受自己控制,那么这块内存就需要程序员自己管理,这样的内存就是在堆区上分配的

栈区和堆区上分配内存性能一样吗

在栈区上分配内存性能更高,原因是栈区上内存的分配和释放非常简单,只是一个指针(寄存器)的移动。
而堆区的内存是由程序员自己控制 的,生命周期各不相同,因此堆区中的内存需要精心标记哪些是可用的哪些是不可用的。更加糟糕的,进程中的所有线程共享一个堆区,因此堆区内存分配器必须处理好线程安全的问题,这些让堆区的内存管理比栈区复杂得多,因此性能差了一些。

栈区和堆区大小一样吗

栈区大小固定的,并且容量有限,具体大小是由操作系统控制的,因此不能创建占据内存空间很大的局部变量,否则会导致栈溢出。

相比栈区,堆区容量更大,理论上讲,堆区的容量是由进程地址空间(独属于进程的内存空间)限制的,而不受物理内存大小限制。此外,如果在堆区上申请内存,必须保证堆区申请的内存被释放掉,否则会导致内存泄漏,而栈区上的内存则没有这个问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值