栈和堆

Posted step by step,go along

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了栈和堆相关的知识,希望对你有一定的参考价值。

  • 栈:存储值类型(有时候翻译成“堆栈”)
    • 无ARC(自动引用计数)负担,由系统自动管理,以执行函数为单位(一个函数一个栈)
    • 空间大小编译时决定(根据参数和局部变量可以确定)
    • 函数执行时,系统自动分配一个栈
    • 函数执行结束,系统会立即回收stack
    • 函数之间通过拷贝值传递
    • 具有局限性,大小有限额,超出会stack overflow(栈溢出)(一般是超大递归、死循环情况)

       

  • 堆:存储引用类型对象
    • 分配由程序员手动请求([a alloc])(c语言里面的malloc)
    • 释放有两种方式,可以手工,也可以ARC机制自动释放
    • 函数之间通过拷贝引用(指针)传递
    • 具有全局性,总体大小无限制(受限于系统内存整体大小)

以上是关于栈和堆的主要内容,如果未能解决你的问题,请参考以下文章

为啥会有栈和堆?

为啥会有栈和堆?

栈和队列的区别,栈和堆的区别

Java栈和堆内存管理

JAVA中的栈和堆

栈和堆