狂自私

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

C语言复习:内存模型2

函数调用模型

基本原理

实际上就是不断的从一个内存跳到另一个内存。

函数调用变量传递分析

  1. 一个主程序有n函数组成,c++编译器会建立有几个堆区?有几个栈区?

    答:一个程序只有一个堆区和一个栈区。

  2. 函数嵌套调用时,实参地址传给形参后,C++编译器如何管理变量的生命周期?

    上一级的变量在下一级调用中可以使用,传参后上级变量依旧存在。下级的变量不能在上级中调用,在堆区开辟的变量除外。上级下级变量的生命周期主要是由于栈的特点决定的:先入后出,后入先出

分析:函数A,调用函数B,通过参数传递的变量(内存空间能用吗?)

提示:建立正确的程序运行内存布局是学好C的关键。

注意野指针;

栈区的生长方向;

posted on   狂自私  阅读(158)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示