内存中的堆和栈

来源:互联网 发布:淘宝订单存在异常 编辑:程序博客网 时间:2024/05/17 08:54

内存结构:

堆区,栈区,全局区,文字常量区,程序代码区

栈:

栈是你的电脑内存的一个特别区域,它用来存储被每一个function(包括mian()方法)创建的临时变量。栈是FILO,就是先进后出原则的结构体,它密切的被CPU管理和充分利用。每次function声明一个新的变量,它就会被“推”到栈中。然后每次一个function退出时,所有关于这个函数中定义的变量都会被释放(换句话说就是删除)。一旦栈中的变量释放,这块区域就会变成可用的,提供给其他栈中的变量。

用栈存储变量的好处:

内存是被你管理的。你不用手动的创建内存,不用当你不在需要它的时候手动释放内存。另外,由于CPU组织栈内存很高效。读出和写入栈变量是很快的。

栈的概念:

当一个function退出时,所有它的变量都会从栈中弹出,以后都会永远消失。因此栈中的变量本质是局部的。这和我们原来理解为变量作用域或者本地或者全局变量是相关的。在C中,一个公共的bug 是从你程序中的一个function外尝试访问一个在栈中的这个function的变量(在该function已经退出后)。

     关于栈的另一个特点我们应该记住,就是存储在栈中的变量的大小有限制。而堆上创建变量不用考虑。

     总结栈:

      a、栈的伸长和伸缩就是函数压入或者推出局部变量。

      b、我们不用自己去管理内存,变量创建和释放都是自动的。

      c、栈中的变量只有在函数创建运行时存在。

堆:

 堆也是我们的计算机内存中的一个区域,但是他不是自动管理的。而且也不是被CPU密切的管理着。它是一片更加自由的内存区域(很大)。要想在堆上创建内存,我们必须使用malloc()或者calloc(),他们都是C语言编译的。一旦你在堆上分配内存,当你不在需要的时候你必须用free()去销毁。如果你不销毁或者销毁失败,你的程序就会有内存泄露。换句话说就是堆内存会一直在,其他进程无法使用。

     堆没有变量大小的限制(除了你电脑的物理限制条件外)。堆内存读出和写入都比较慢,因为它必须使用指针图访问堆内存。

栈和堆的优缺点:

  栈:

  1)、快速访问。

  2)、没有必要明确的创建分类变量,因为它是自动管理的。

  3)、空间被CPU高效地管理着,内存不会变成碎片。

  4)、只有局部变量

  5)、受限于栈大小(取决于操作系统)

  6)、变量不能调整大小。

  堆:

  1)、变量可以被全局访问

  2)、没有内存大小限制

  3)、(相对)访问比较慢

  4)、没有高效地使用空间,随着块内存的创建和销毁,内存可能会变成碎片。

  5)、你必须管理内存(变量的创建和销毁你必须要负责)

  6)、变量大小可以用realloc( )调整

原创粉丝点击