我之前以为堆栈就是一个名词,现在听别人说才知道,堆是堆,栈是栈,是不一样的!那么,这两者有神马区别啊??怎么用??

上传的附件
你的回答被采纳后将获得: 8点积分 (将会扣除手续费1点积分。)

keyboard_arrow_left上一篇 : 求官方的VS2012的下载链接 学习java 看书好呢还是看视频好呢 : 下一篇keyboard_arrow_right

4个回答

Foooooooood
2019-01-08 08:47:05

  • 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等

  • 栈是向低地址扩展的数据结构,是一块连续的内存的区域。是栈顶的地址和栈的最大容量是系统预先规定好的,栈的大小是2M(也有的说是1M,总之是一个编译时就确定的常数 )

  • 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收

  • 堆是向高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表来存储的空闲内存地址的,自然是不连续的,而链表的遍历方向是由低地址向高地址。堆的大小受限于计算机系统中有效的虚拟内存

Carewho
2019-03-27 09:59:42

局部变量存储在栈里,全局变量存储在堆里

asxsxs
2020-12-01 21:53:53

底层实现的数据结构不一样,一般来说创建对象都存在堆内存中,而你声明的变量这些都是在栈中,声明的对象也是的。不得不提还有静态代码块

汉堡
2020-12-24 14:31:36

堆和栈的区别主要有五大点,分别是:

1、申请方式的不同。栈由系统自动分配,而堆是人为申请开辟;

2、申请大小的不同。栈获得的空间较小,而堆获得的空间较大;

3、申请效率的不同。栈由系统自动分配,速度较快,而堆一般速度比较慢;

4、存储内容的不同。栈在函数调用时,函数调用语句的下一条可执行语句的地址第一个进栈,然后函数的各个参数进栈,其中静态变量是不入栈的。而堆一般是在头部用一个字节存放堆的大小,堆中的具体内容是人为安排;

5、底层不同。栈是连续的空间,而堆是不连续的空间。

精彩评论

  • 分时操作系统中CPU的时间片是越长越好还是越短越好?
    1、优点:缩短周转时间,以及等待时间,提高系统的吞吐量。2、缺点:延长长作业时间,长时间得不到执行,影响调度性能。3、根据任务执行时间长度设置时间片
    2020-11-16 09:06:01 thumb_up( 2 )
  • 说说最近的感想吧(最佳答案不止一个)
    写论文到头秃,计算机学生英语和写作能力也很重要
    2020-06-03 12:22:20 thumb_up( 4 )
  • 说说最近的感想吧(最佳答案不止一个)
    业余时间学学数据结构及算法。。。还有数据库。最好弄个游戏类的软件代码改一改,玩一玩,学一学。
    2020-08-21 10:16:58 thumb_up( 2 )
  • [算法问题] 谁逃课了
    我也看了这个问题,可能是因为输出格式问题没有ac吧……我用了C语言的位运算,用单个数字表示五个人的逃课状况,比如00000就是都没逃课,01100就是只有BC逃课。用到了位进制运算符>>和<<,在递归函数中用了swich,最大数字是32,用char也可以,占用空间会小一些。 我的代码长这样: include<stdio.h>include<stdlib.h>/A->B; BvC; (C^D)v(-C^-D); DvE; E->(A^D)/ int check(int ans) { if ((ans >> 4) && (ans >> 3) % 2 == 0) return 0; if ((((ans >> 3) % 2) && ((ans >> 2) % 2)) || (!((ans >> 3) % 2) && !((ans >> 2) % 2))) return 0; if (((ans >> 2) % 2) - ((ans >> 1) % 2)) return 0; if (!((ans >> 1) % 2) && !(ans % 2)) return 0; if ((ans % 2) && (!(ans >> 4) || !(ans >> 1) % 2)) return 0; return 1;} int ans(int i, int now) { int a; switch (i) { case 1:{ a = ans(2, 0); if(a) return a; else return ans(2, 1); break; } case 2:{ a = ans(3, (now << 1)); if(a) return a; else return ans(3, (now << 1) + 1); break; } case 3:{ a = ans(4, now << 2); if(a) return a; else return ans(4, (now << 1) + 1); break; } case 4:{ a = ans(5, now << 2); if(a) return a; else return ans(5, (now << 1) + 1); break; } case 5:{ now = (now << 1); if (check(now)) return now; else if (check(++now)) return now; else return 0; break; } default: break; }} int main () { int Ans; Ans = ans(1, 0); if (Ans >> 4) printf(“A”); if ((Ans >> 3) % 2) printf(“B”); if ((Ans >> 2) % 2) printf(“C”); if ((Ans >> 1) % 2) printf(“D”); if ((Ans >> 0) % 2) printf(“E”); printf(“\n”); return 0;}
    2021-03-03 11:53:43 thumb_up( 1 )
  • [算法问题] 谁逃课了
    我也看了这个问题,可能是因为输出格式问题没有ac吧……我用了C语言的位运算,用单个数字表示五个人的逃课状况,比如00000就是都没逃课,01100就是只有BC逃课。用到了位进制运算符>>和<<,在递归函数中用了swich,最大数字是32,用char也可以,占用空间会小一些。 我的代码长这样:
    2021-03-03 11:51:38 thumb_up( 1 )
  • [算法问题] 谁逃课了
    给你个借鉴吧 我这边是php语言的基本语法如下:直接一个类实现 /** * 1)如果A逃课,B也一定逃课 * 2)B和C中有且只有一个人参与逃课 * 3)C和D要么都逃,要么都不逃 * 4)D和E至少有一个人逃了 * 5)如果E逃课,则A和D一定参与逃课 */class Truancy{ private $first = 'A'; public $set_list = []; public function __construct($first = ''){ if($first) $this->first = $first; array_push($this->set_list , $this->first); $this->relationship(); } // 主要逻辑 private function relationship(){ if(in_array('A',$this->set_list)){ array_push($this->set_list , 'B'); } if(in_array('B',$this->set_list)){ if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); } if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); } } if(in_array('C',$this->set_list)){ if(in_array('B',$this->set_list)){ $key = array_search('B'); unset($this->set_list[$key]); } if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } } if(in_array('D',$this->set_list) == false){ if(in_array('E',$this->set_list) == false){ $key = rand(1,2); $array_de = ['D','E']; // 两个随机出一个 如果两个都没有逃课的情况任意选择一个 array_push($this->set_list , $array_de[$key-1]); } } if(in_array('E',$this->set_list)){ if(in_array('D',$this->set_list) == false){ array_push($this->set_list , 'D'); } if(in_array('A',$this->set_list) == false){ array_push($this->set_list , 'A'); array_push($this->set_list , 'B'); if(in_array('C',$this->set_list)){ $key = array_search('C'); unset($this->set_list[$key]); $key = array_search('D'); unset($this->set_list[$key]); } } } // 将结果变成字符串显示(数组集合变成字符串) function merge_arr($v1,$v2) { return $v1 . "" . $v2; } sort($this->set_list); $this->set_list = array_reduce($this->set_list,merge_arr); }}$Truancy = new Truancy("B");// 输出结果var_dump($Truancy->set_list) ;
    2021-01-20 09:35:09 thumb_up( 1 )
  • 基于MFC中创建的TCP/IP中TCP的端点是什么?本机IP地址还是套接字?
    套接字
    2020-12-02 20:21:22 thumb_up( 1 )
eject