堆栈

原创 2016年08月31日 09:53:04

进程映像

  1. 程序是保存在磁盘上的可执行文件。

  2. 运行程序时,需要将可执行文件加载到内存,形成进程。

  3. 一个程序(文件)可以同时存在多个进程(内存)。

  4. 进程在内存空间中的布局就是进程映像。从低地址到高地址依次为:

代码区(text):可执行指令、字面值常量、具有常属性的全局和静态局部变量。只读。

数据区(data):初始化的全局和静态局部变量。 有初值,直接存在程序文件中。

BSS区:未初始化的全局和静态局部变量。进程一经加载此区即被清0。

数据区和BSS区有时被合称为全局区或静态区。

堆区(heap):动态内存分配。从低地址向高地址扩展。

栈区(stack):非静态局部变量,包括函数的参数和返回值。从高地址向低地址扩展。

堆区和栈区之间存在一块间隙,一方面为堆向上和栈向下的增长预留空间,同时共享库、共享内存等亦位于此。
这里写图片描述
代码如下:

#include <stdio.h>
#include <stdlib.h>

const int const_global = 0; // 常全局变量
int init_global = 0; // 初始化全局变量
int uninit_global; // 未初始化全局变量

int main (int argc, char* argv[]) {
    const static int const_static = 0; // 常静态变量
    static int init_static = 0; // 初始化静态变量
    static int uninit_static; // 未初始化静态变量

    const int const_local = 0; // 常局部变量
    int prev_local; // 前局部变量
    int next_local; // 后局部变量

    int* prev_heap = malloc (sizeof (int)); // 前堆变量
    int* next_heap = malloc (sizeof (int)); // 后堆变量

    const char* literal = "literal"; // 字面值常量
    extern char** environ; // 环境变量

    printf ("---- 命令行参数与环境变量 ---- <高>\n");
    printf ("         环境变量:%p\n", environ);
    printf ("       命令行参数:%p\n", argv);
    printf ("-------------- 栈 ------------\n");
    printf ("       常局部变量:%p\n", &const_local);
    printf ("       前局部变量:%p\n", &prev_local);
    printf ("       后局部变量:%p\n", &next_local);
    printf ("-------------- 堆 ------------\n");
    printf ("         后堆变量:%p\n", next_heap);
    printf ("         前堆变量:%p\n", prev_heap);
    printf ("------------- BSS ------------\n");
    printf (" 未初始化全局变量:%p\n", &uninit_global);
    printf (" 未初始化静态变量:%p\n", &uninit_static);
    printf ("------------ 数据 ------------\n");
    printf ("   初始化静态变量:%p\n", &init_static);
    printf ("   初始化全局变量:%p\n", &init_global);
    printf ("------------ 代码 ------------\n");
    printf ("       常静态变量:%p\n", &const_static);
    printf ("       字面值常量:%p\n", literal);
    printf ("       常全局变量:%p\n", &const_global);
    printf ("             函数:%p\n", main);
    printf ("------------------------------ <低>\n");

    printf ("查看/proc/%u/maps,按<回车>退出...", getpid ());
    getchar ();

    return 0;
}

运行结果如下:
这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/feike24/article/details/52382030

实验2堆栈模板.rar

  • 2009年06月22日 09:14
  • 227KB
  • 下载

关于堆栈的讲解(我见过的最经典的)

这是一篇转发的文章,我对他进行了格式化而已,原文出处不详。一、预备知识—程序的内存分配一个由c/C++编译的程序占用的内存分为以下几个部分 1、栈区(stack)— 由编译器自动分配释放 ,存放函数...
  • yingms
  • yingms
  • 2016-11-16 17:31:36
  • 7863

PS菜鸟入门 -- PS堆栈

一、首先看一下 PS堆栈 效果图:(取自网上)二、摄取图片首先,准备好三脚架和快门线。然后,构图。定好焦距、焦点、光圈、快门、ISO等,连续拍摄N张照片。最后,使用 PS 堆栈。这部分,再讲一个利用 ...
  • qq_29350001
  • qq_29350001
  • 2017-06-01 17:55:33
  • 4091

汇编基础教程(三)——堆栈框架

由于之前转载的那个教程最后一篇,代码太长了,虽然注释很详细但我实在看不下去了。。。原文在这里 于是根据《INTEL汇编程序设计第五版》第八章8.2小结以及网上的内容整理如下。 ----------...
  • candycat1992
  • candycat1992
  • 2012-10-30 23:25:51
  • 5194

java的堆栈,很详细的资料

  • 2011年05月06日 08:52
  • 56KB
  • 下载

重要的数据结构--堆栈

先declare下,此堆栈(stack)不是内存中的stack,而是一种十分重要的数据结构,后进先出(LIFO)的数据结构。 堆栈区别于树和图,是一种顺序结构,它只能在一端进行增加元素,或者删除元素的...
  • nigel_lee_beihang
  • nigel_lee_beihang
  • 2016-11-28 15:25:17
  • 722

如何自定义实现堆栈?

java中堆栈的简单实现
  • qq_25827845
  • qq_25827845
  • 2017-04-27 17:47:59
  • 1281

面试题集-堆栈和队列

如何准备: Whether you are asked to implement a simple stack / queue, or you are asked to implementa mod...
  • coder_xia
  • coder_xia
  • 2012-08-30 09:37:23
  • 4263

堆栈的C++实现!!!

  • 2008年05月25日 15:10
  • 7KB
  • 下载

堆栈的工作原理

声明:以下均为个人见解,错漏地方还请指正 每一个使用c语言的都应该知道栈的重要性,我们能够使用C/C++语言写出诸多复杂的程序,很大功劳一部分有归于栈的实现,因为它可以帮助我们实现函数间的嵌套调用...
  • lee244868149
  • lee244868149
  • 2015-10-29 21:52:39
  • 4876
收藏助手
不良信息举报
您举报文章:堆栈
举报原因:
原因补充:

(最多只允许输入30个字)