堆栈

原创 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;
}

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

线性表、堆栈、队列

  • 2017年04月08日 22:01
  • 1.38MB
  • 下载

Linux中gdb 查看core堆栈信息

core dump 一般是在segmentation fault(段错误)的情况下产生的文件,需要通过ulimit来设置才会得到的。 调试的话输入: gdb filename core f...

2015-01-16(内存地址_堆栈).part2

  • 2015年12月04日 21:34
  • 70MB
  • 下载

斐波拉切堆栈c++

  • 2015年05月28日 00:18
  • 1KB
  • 下载

python数据结构学习笔记-4-堆栈 队列

堆栈、队列
  • hjh00
  • hjh00
  • 2015年11月02日 17:19
  • 1057

uCOS任务堆栈的深入分析

  • 2014年11月17日 10:05
  • 29KB
  • 下载

Android下打印调试堆栈方法

打印堆栈是调试的常用方法,一般出现异常时,我们可以在跑出异常时也将堆栈情况打印出来,这样十分方便错误查找。另外实际上也有一个非常有用的功能:分析代码的行为。android代码太过庞大了,完全的静态分析...
  • freshui
  • freshui
  • 2013年07月26日 10:38
  • 76568

堆栈的用法

  • 2016年02月25日 18:31
  • 1KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:堆栈
举报原因:
原因补充:

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