博客
关于我
程序的内存分区模型
阅读量:134 次
发布时间:2019-02-28

本文共 646 字,大约阅读时间需要 2 分钟。

执行过程

在编译过程中,程序的执行可以分为几个关键阶段:
  • 预处理阶段:这一阶段主要包括宏定义展开、头文件处理以及条件编译。需要注意的是,预处理阶段不会对语法进行检查,这通常是编译阶段的任务。
  • 编译阶段:预处理完成后,编译器会对处理后的源代码进行语法检查,并将其转换为汇编语言文件。
  • 汇编阶段:汇编语言文件会被转换为目标文件(通常是二进制文件)。
  • 链接阶段:目标文件会被链接起来,生成最终的可执行程序。
  • 内存分区

    程序在运行时,内存会被划分为不同的区域,这些区域在功能上有明确的区别:
    • 代码区:存储程序的代码和常量。
    • 数据区:存储全局变量(已初始化和未初始化的)。
    • 栈区:用于函数调用的本地存储,属于先进后出的数据结构,由编译器自动管理。
    • 堆区:由程序员动态分配和释放,容量通常远大于栈区。

    运行前

    在程序运行之前,内存的分配情况如下:
    • 代码区

      • 共享内存:用于多个进程共享。
      • 只读内存:通常用于存放只读数据,如常量。
    • 数据区

      • 已初始化的全局变量和静态变量:在程序启动时就被分配了内存。
      • 未初始化的全局变量和静态变量:在程序运行时才会被分配内存。

    运行后

    程序运行后,内存的使用情况会发生变化:
    • 栈区

      • 栈是先进后出的数据结构,适合用于函数调用时的本地存储。
      • 栈中的变量会在函数结束后自动释放。
    • 堆区

      • 堆区的容量远大于栈区,且没有先进后出的特性。
      • 堆内存的分配和释放需要程序员主动管理,常见的方法是使用mallocfree函数。
      • 需要注意的是,堆内存如果没有正确释放,可能会导致内存泄漏。

    转载地址:http://kaad.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>
    NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
    查看>>
    Nitrux 3.8 发布!性能全面提升,带来非凡体验
    查看>>
    NI笔试——大数加法
    查看>>
    NLP 基于kashgari和BERT实现中文命名实体识别(NER)
    查看>>
    NLP学习笔记:使用 Python 进行NLTK
    查看>>
    NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
    查看>>
    NLP:使用 SciKit Learn 的文本矢量化方法
    查看>>
    Nmap扫描教程之Nmap基础知识
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NMF(非负矩阵分解)
    查看>>