栈(stack)和堆(heap)的区别:
- 栈:存储值类型(有时候翻译成“堆栈”)
- 无ARC(自动引用计数)负担,由系统自动管理,以执行函数为单位(一个函数一个栈)
- 空间大小编译时决定(根据参数和局部变量可以确定)
- 函数执行时,系统自动分配一个栈
- 函数执行结束,系统会立即回收stack
- 函数之间通过拷贝值传递
- 具有局限性,大小有限额,超出会stack overflow(栈溢出)(一般是超大递归、死循环情况)
- 堆:存储引用类型对象
- 分配由程序员手动请求([a alloc])(c语言里面的malloc)
- 释放有两种方式,可以手工,也可以ARC机制自动释放
- 函数之间通过拷贝引用(指针)传递
- 具有全局性,总体大小无限制(受限于系统内存整体大小)
-
栈与堆的区别
本文详细解释了计算机科学中栈和堆两种内存管理方式的区别。栈主要用于存储值类型数据,其生命周期与函数调用紧密相关;堆则用于存储引用类型对象,具有全局性和更大的灵活性。
756

被折叠的 条评论
为什么被折叠?



