堆和栈的区别整理

来源:互联网 发布:淘宝导航设置颜色代码 编辑:程序博客网 时间:2024/06/04 19:08

一、预备知识:程序的内存分配(C/C++编译的程序)

  1. 栈区(stack)—由编译器自动分配释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈;
  2. 堆区(heap)—一般由程序员分配释放,若程序员不释放,程序结束时可能由OS回收。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表;
  3. 全局区(静态区static)—全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域,程序结束后由系统释放;
  4. 文字常量区—常量字符串就是放在这里的,程序结束后由系统释放;
  5. 程序代码区—存放函数体的二进制代码。

二、实例程序

 int a = 0;//全局初始化区     char *p1;//全局未初始化区     void main(void)     {        int b;//栈        char s[] = "abc";//栈        char *p2;//栈        char *p3 = "123456";//123456/0在常量区,p3在栈上。        static int c = 0;//全局(静态)初始化区        p1 = (char *)malloc(10);        p2 = (char *)malloc(20);        //分配得来得10和20字节的区域就在堆区。        strcpy(p1, "123456"); //123456/0放在常量区,编译器可能会将它与p3所指向的"123456"优化成一个地方。     }    

三、小结

  1. 使用栈就象我们去饭馆里吃饭,只管点菜(发出申请)、付钱、和吃(使用),吃饱了就走,不必理会切菜、洗菜等准备工作和洗碗、刷锅等扫尾工作,他的好处是快捷,但是自由度小。
  2. 使用堆就象是自己动手做喜欢吃的菜肴,比较麻烦,但是比较符合自己的口味,而且自由度大。(经典!)
原创粉丝点击