DSP

操作系统中heap和stack的区别?

2019-07-13 19:29发布

参考:http://blog.csdn.net/guan_sen/article/details/78769487--堆栈是两种数据结构堆栈都是一种数据项按序排列的数据结构,只能在一端对数据项进行插入和删除。在单片机应用中,堆栈是个特殊的存储区,主要功能是暂时存储数据和地址。要点:堆:队列优先,先进先出 栈:先进后出
  • 堆栈空间分配区别
    • 栈:由系统自动分配释放,存放函数的参数值,局部变量等,操作方法类似数据结构中的栈
    • 堆:一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收,分配方式类似于链表
  • 堆栈缓存方式区别
    • 栈使用的是一级缓存,他们通常被调用时处于存储空间中,调用完毕立即释放
    • 堆是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法决定,所以调用这些对象速度相对较低
  • JAVA中堆栈的区别
    • 堆(heap)和栈(stack)都是Java用来在Ram中存放数据的地方,与C++不同,Java自动管理堆栈,程序员不能直接设置堆或者栈。
    • 在函数中定义的一些基本类型的变量和对象的引用变量都在函数的栈内存中分配。当在一段代码块中定义一个变量时,Java就在栈中为这个变量分配内存空间,当超过变量的作用域后,Java会自动释放掉为该变量分配的内存空间,该内存空间可以立即另做他用。
    • 堆内存用来存放由new创建的对象和数组。在堆中分配的内存,由Java虚拟机的自动垃圾回收器来管理,在堆中产生了一个数组或对象后,还可以在栈中定义一个特殊的变量,让栈中这个变量的取值等于数组或对象在堆内存中的首地址,栈中的这个变量就成了数组或对象的引用变量。应用变量就相当于是为数组或对象起的一个名称,可以在程序中使用栈的引用变量来访问堆中的数组或对象。
  • Java变量在内存中的分配
    • 类变量(static修饰):在程序加载时系统就为它在堆中开辟内存,堆中的内存地址存放于栈中以便于快速访问。静态变量的生命周期一直持续到整个“系统”关闭。
    • 实例变量:当你使用Java关键字new的时候 ,系统在堆中开辟并不一定是连续空间分配给变量(类实例),然后根据零散的堆内存地址,通过哈希算法换算为一长串数字以表征这个变量在堆中的“物理位置”。实例变量的生命周期-当实例变量的引用丢失后,将被GC列入可回收名单,但并不马上释放堆中内存。
    • 局部变量:申明在某方法或某代码块中的变量,执行到它的时候在栈中开辟内存,当局部变量一旦脱离作用域,内存立即释放。