博客
关于我
内存分布、内存处理函数 --- 2021.4.16
阅读量:264 次
发布时间:2019-03-01

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

内存分布与内存处理函数

内存分布是程序运行时内存管理的重要基础。在实际应用中,我们常常会遇到内存如何分配的问题。例如,在程序中定义的变量,编译器会自动为这些变量分配内存空间。了解内存分布有助于更好地理解操作系统的内存管理机制。

在介绍内存分布之前,我们需要先了解几个关键概念:

  • 作用域:变量的作用范围,即该变量在程序运行中可以使用的时间段。
  • 普通局部变量:定义在{}范围内的变量,其内存分配和释放与函数的调用和返回同步。
  • 静态局部变量:定义在{}范围内且使用static修饰的变量,其内存预先分配,与函数的调用无关。
  • 全局变量:在函数外定义的变量,其内存分配和释放与程序的启动和退出相关。
  • 静态全局变量:在函数外定义且使用static修饰的变量,其内存预先分配,与程序的启动和退出相关。
  • 静态函数:定义在函数前使用static修饰的函数,该函数只能在当前文件中使用。
  • 这些变量的内存分布通常分为几个部分:栈区、堆区、静态全局区、文字常量区和代码区。代码区用于存放程序代码,而文字常量区则用于存放字符串常量。

    以一段示例代码为例:

    int e; static int f; int g = 10; static int h = 10; int main() {int a; int b = 10; static int c; static int d = 10; char *i = "test"; char *k = NULL;}

    对应的内存分布如下:

  • 代码区:存放程序代码。
  • 文字常量区:存放字符串"test"。
  • 静态全局区:包括未初始化的静态全局变量(如e和f)和初始化的静态全局变量(如h和d)。
  • 堆区:用于动态分配内存,例如使用malloc函数。
  • 栈区:存放普通局部变量和静态局部变量(如a和b)。
  • BSS区:存放未初始化的静态全局变量(如e和f)。
  • 内存处理函数是内存管理的重要工具。以下是常用的内存处理函数:

  • memset函数:将内存区域的前n个字节设置为指定的字符。例如:

    #include 
    void *memset(void *s, int c, size_t n);

    该函数返回s的首地址。

  • memcpy函数:将源内存区域的前n个字节拷贝到目标内存区域。例如:

    #include 
    void *memcpy(void *dest, const void *src, size_t n);

    该函数返回目标内存区域的首地址。

  • memcmp函数:比较源内存区域和目标内存区域的前n个字节。例如:

    #include 
    int memcmp(const void *s1, const void *s2, size_t n);

    该函数返回0(相等)、正数(s1大于s2)或负数(s1小于s2)。

  • 这些函数在实际开发中广泛应用,为内存管理提供了强大的工具。通过合理使用这些函数,可以有效管理内存资源,提高程序的性能和稳定性。

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

    你可能感兴趣的文章
    ORACLE Active dataguard 一个latch: row cache objects BUG
    查看>>
    oracle avg、count、max、min、sum、having、any、all、nvl的用法
    查看>>
    Oracle BEQ方式连接配置
    查看>>
    oracle Blob保存方式,oracle 存储过程操作blob
    查看>>
    Oracle BMW Racing sailing vessel帆船图
    查看>>
    ORACLE Bug 4431215 引发的血案—原因分析篇
    查看>>
    Oracle Business Intelligence Downloads
    查看>>
    Oracle cmd乱码
    查看>>
    Oracle Corp甲骨文公司推出Oracle NoSQL数据库2.0版
    查看>>
    【Docker知识】将环境变量传递到容器
    查看>>
    uniapp超全user-agent判断 包括微信开发工具 hbuilder mac windows 安卓ios端及本地识别
    查看>>
    Oracle DBA课程系列笔记(20)
    查看>>
    oracle dblink 创建使用 垮库转移数据
    查看>>
    oracle dblink结合同义词的用法 PLS-00352:无法访问另一数据库
    查看>>
    Oracle dbms_job.submit参数错误导致问题(ora-12011 无法执行1作业)
    查看>>
    oracle dg switchover,DG Switchover fails
    查看>>
    Oracle E-Business Suite软件 任意文件上传漏洞(CVE-2022-21587)
    查看>>
    Oracle EBS OPM 发放生产批
    查看>>
    Oracle EBS-SQL (BOM-15):检查多层BOM(含common BOM).sql
    查看>>
    Oracle EBS环境下查找数据源(OAF篇)
    查看>>