博客
关于我
内存分布、内存处理函数 --- 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用户改名
    查看>>
    oracle用户解压不了,PLSQL developer 连接不上64位Oracle 的解决方法
    查看>>
    oracle用户解锁
    查看>>
    Oracle用游标删除重复数据
    查看>>
    oracle的内置函数
    查看>>
    Oracle的存储结构
    查看>>
    Oracle的聚合函数group by结合CUBE和ROLLUP的使用
    查看>>
    Oracle监听配置、数据库实例配置等
    查看>>
    Oracle笔记(十三) 视图、同义词、索引
    查看>>
    Oracle笔记(十) 约束
    查看>>
    Oracle系列:安装Oracle RAC数据库(二)
    查看>>
    oracle系统 介绍,ORACLE数据库管理系统介绍
    查看>>
    oracle获取数据库表、字段、注释、约束等
    查看>>
    oracle表空间查询维护命令大全之三(暂时表空间)史上最全
    查看>>
    oracle表访问方式
    查看>>
    Oracle触发器
    查看>>
    Oracle计划将ZGC项目提交给OpenJDK
    查看>>
    oracle账号共享
    查看>>
    Oracle闪回技术(Flashback)
    查看>>
    oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
    查看>>