a不是在栈底吗,不是说栈底地址比栈顶高吗。脑子有点迷糊,求解答
2条回答 默认 最新
- Web Security Loop 2023-03-01 15:43关注
栈是从高地址往低地址增长的,也就是说栈顶的地址比栈底的地址低。这个你是懂的。
在函数调用时,局部变量通常被分配在栈上,而且它们的相对位置是由它们在函数中声明的顺序决定的。假设在一个函数中,变量 a 的声明在变量 b 的前面,那么在栈上分配内存时,a 的地址就比 b 的地址低。
给你看一段代码,a 的声明在 b 的前面,因此在栈上分配内存时,a 的地址比 b 的地址低:#include <stdio.h> int main() { int a = 1; int b = 2; printf("a: %p\n", &a); printf("b: %p\n", &b); return 0; }
运行的结果是:
a: 0x7ffeeefbff4c b: 0x7ffeeefbff48
可以看到,a 的地址比 b 的地址低,这是因为在栈上分配内存时,a 的地址比 b 的地址先分配。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 python点云生成mesh精度不够怎么办
- ¥15 QT C++ 鼠标键盘通信
- ¥15 改进Yolov8时添加的注意力模块在task.py里检测不到
- ¥50 高维数据处理方法求指导
- ¥100 数字取证课程 关于FAT文件系统的操作
- ¥15 如何使用js实现打印时每页设置统一的标题
- ¥15 安装TIA PortalV15.1报错
- ¥15 能把水桶搬到饮水机的机械设计
- ¥15 Android Studio中如何把H5逻辑放在Assets 文件夹中以实现将h5代码打包为apk
- ¥15 使用小程序wx.createWebAudioContext()开发节拍器