堆区和栈区的区别

一、区别

注:首先堆和栈可以分为两种,一种是数据结构,另一种是和内存的分配有关,这两种虽然都有栈和堆,但是两者关系并不大,

 

c语言的内存模型分为五个区,分别为:堆区(heap)、栈区(stack)、静态区、常量区、代码区、

栈区和代码区其实是一个区。下面这个图就很明了。

 

 

 

栈区主要存储变量、引用,比如int x;bool y;等等,

  存区速度较快,因为他存储的都是一些比较简单的数据,而且他本身的数据接口也比较简单。存储的内容会随着方法的执行完成被销毁

  每个线程都有一个栈

  垃圾回收较为频繁,因为主要是存方法,方法结束那方法中的引用就结束了

堆主要存储的是实例对象,比如new 一个对象,

  存取速度比较慢,因为堆内存要在程序运行时动态分配内存。存储的内容有程序员自己销毁,如果程序执行完成还没有销毁,就自动销毁。

  而所有线程共享一个堆

  垃圾回收不频繁,只有在一定条件下比如不够用了才会回收

 可以来一段c++代码对比一下

 1 #include<iostream>
 2 using namespace std;
 3 int * function(){
 4     int a = 1     #在这里会给变量分配栈内存
 5     return &a;
 6     
 7 }    
 8 int main(){
 9    int *p = function();  #当方法运行完成后,变量就被销毁了
10    cout<<*P<<end1;     #所以输出的*P为乱码
11    cout<<*p<<end1;
12    return 0;            
13 }

要取到a的值,可以new一个对象,

 1 #include<iostream>
 2  using namespace std;
 3  int * function(){
 4       int *a = new int (1)    #调用对象把a存在了堆区,方法运行后并不会被立即清理
 5      return a;
 6       
 7   }    
 8   int main(){
 9     int *p = function();  #
10    cout<<*P<<end1;     #所以输出a的值1
11     cout<<*p<<end1;
12    return 0;            
13 }

 

二、数据结构中的栈和堆

什么是数据结构?

存储与组织数据的方式。我感觉更应强调数据的组织方式,比如好多数据结构的存储方式都是用的数组,但他们根据自身的特点进行了封装,因为存储方式只有顺序存储和链式存储两种,但是却可以组合成多种数据结构。 

常用的数据结构有哪些?

数组、栈、图、堆、队列、链表等等。

栈是限定仅仅在表尾进行插入和删除操作的线性表,把允许插入和删除的一端称之为栈顶,另外一端称之为栈底。特点:后进先出,称之为后进先出线性表。

栈的应用:递归。

是一种经过排序的树形数据结构,每一个节点都有一个值,通常所说堆的数据结构是二叉树,堆的存取是随意的。所以堆在数据结构中通常可以被看做是一棵树的数组对象。而且堆需要满足一下两个性质:
(1)堆中某个节点的值总是不大于或不小于其父节点的值;
(2)堆总是一棵完全二叉树。

堆的应用:堆排序,快速找出最大值、最小值,简化时间复杂度,像这样支持插入元素和寻找最大(小)值元素的数据结构称之为优先队列。
————————————————

原文链接:https://blog.csdn.net/panjiapengfly/article/details/102665381

posted @ 2021-08-05 22:28  搬砖在路上  阅读(1307)  评论(0编辑  收藏  举报