堆,栈,程序区,静态变量,局部变量,函数,参数宏

       堆和栈是堆和栈是在程序运行中用于存储数据和指令的两种不同的内存空间。

堆:堆内存用于分配程序中动态数据结构的内存空间,它的生命周期不由程序的函数调用栈管理,通常会被程序员直接管理。

       堆空间为程序提供了极为灵活的空间分配和管理手段,既可以手动管理,也可以交由垃圾回收机制自动管理,带来了很大的方便。

栈:是一种后进先出(LIFO)的数据结构。程序在运行时,会将栈用来存储函数的调用栈内存的分配操作表达式求值的临时变量以及与程序中的控制流相关的数据

       栈是一种高效的内存结构,用于存放基础数据类型和引用类型的变量,大大简化内存的管理,提高了程序的执行效率。

栈的特点

栈作为一种内存结构,具有以下几个特点:

  1. 后进先出:栈采用后进先出的存储方式,即最后进栈的元素,最先出栈。这是因为栈底部是固定的,每个元素只能从栈顶进入和离开栈。

  2. 自动分配和释放:栈空间是由操作系统自动分配和管理的,创建和销毁栈的操作都不需要程序员手动干预。当程序执行完一个函数后,操作系统就会自动回收该函数的局部变量和临时变量所占用的栈空间。

  3. 固定大小:栈的大小是由操作系统在程序运行时预先分配的,程序员无法直接改变栈的大小。因此,栈的空间大小是固定的,且在程序运行时不可被修改。

  4. 速度快:由于栈空间是由操作系统直接分配和管理的,因此栈的访问速度比较快,不像堆需要动态申请和释放内存。另外,栈的空间地址是连续的,因此访问数据也比较方便。

 

堆的特点

堆作为一种内存结构,具有以下几个特点:

  1. 动态分配和释放:堆空间是程序运行时自由存储的内存空间,程序可以动态申请和释放堆空间,因此可以灵活地管理内存。

  2. 大小不定:堆的大小不固定,可以根据需要动态调整。当程序需要存储大型对象或大量数据时,堆是更适合的选择,因为堆不会像栈一样因固定大小而限制数据存储量。

  3. 分配策略:堆内存的分配使用的是由程序员手动分配。分配时需要指定需要分配的内存大小,同时操作系统还需要进行一些额外的内存管理工作。

  4. 空间碎片化:由于堆空间的动态申请和释放,可能会导致内存空间出现碎片化的问题,这会影响程序的运行性能。

  5. 效率较低:由于堆空间的内存分配和释放需要频繁进行内存分配和回收,并且操作系统需要进行额外的内存管理工作,因此堆的效率相对较低。

栈通常被用于存储程序中的函数调用、中断处理和异常处理等。下面是一些栈在计算机底层的应用:

  1. 函数调用:当一个函数被调用时,程序会把该函数的参数、返回地址和局部变量等信息存入栈中。当函数执行完成后,栈会弹出这些信息并恢复函数调用前的状态。

  2. 中断处理:当计算机硬件或软件发生中断时,操作系统会自动保存当前进程的执行现场,包括CPU状态、程序计数器、寄存器等信息,然后将控制权转移至中断处理程序。中断处理程序执行完成后,栈会弹出保存的现场信息并恢复中断前的状态。

  3. 程序调试:在程序调试过程中,开发人员可以使用栈来查看当前程序的执行状态,例如变量的值、函数调用栈、异常处理等。

  4. 操作系统中的进程调度:栈也被用于操作系统中的进程调度和任务切换。当进程切换时,操作系统会把当前进程的上下文信息存储在栈中,然后恢复下一个进程的上下文信息。

  • 24
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个示例程序,其中包含局部变量、全局变量、全局静态变量、局部静态变量以及函数: ```c++ #include <iostream> // 全局变量 int globalVar = 10; // 全局静态变量 static int globalStaticVar = 20; // 函数声明 void exampleFunction(); int main() { // 局部变量 int localVar = 30; std::cout << "Global variable value: " << globalVar << std::endl; std::cout << "Global static variable value: " << globalStaticVar << std::endl; std::cout << "Local variable value: " << localVar << std::endl; exampleFunction(); exampleFunction(); exampleFunction(); return 0; } // 函数定义 void exampleFunction() { // 局部静态变量 static int staticVar = 0; // 输出各个变量的值 std::cout << "Global variable value: " << globalVar << std::endl; std::cout << "Global static variable value: " << globalStaticVar << std::endl; std::cout << "Static variable value: " << staticVar << std::endl; // 将静态变量递增 staticVar++; } ``` 在这个程序中,我们定义了一个全局变量 `globalVar` 和一个全局静态变量 `globalStaticVar`,它们可以在程序的任何地方访问。在 `main()` 函数中,我们定义了一个局部变量 `localVar`,它只能在 `main()` 函数中访问。 我们还定义了一个函数 `exampleFunction()`,其中包含一个局部静态变量 `staticVar`,它只能在 `exampleFunction()` 函数内部访问。 在 `main()` 函数中,我们输出了各个变量的值,并调用了三次 `exampleFunction()` 函数。在 `exampleFunction()` 函数中,我们输出了各个变量的值,并将静态变量 `staticVar` 递增。 运行结果如下所示: ``` Global variable value: 10 Global static variable value: 20 Local variable value: 30 Global variable value: 10 Global static variable value: 20 Static variable value: 0 Global variable value: 10 Global static variable value: 20 Static variable value: 1 Global variable value: 10 Global static variable value: 20 Static variable value: 2 ``` 我们可以看到,全局变量、全局静态变量局部变量在任何地方都可以访问,而局部静态变量只能在函数内部访问。同时,全局变量和全局静态变量的值在整个程序的生命周期中都是保持不变的,而局部变量和局部静态变量的值只在函数调用期间存在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值