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 的地址先分配。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 阿里云python代码求解
- ¥20 有人知道这种图怎么画吗?
- ¥15 pyqt6如何引用qrc文件加载里面的的资源
- ¥15 安卓JNI项目使用lua上的问题
- ¥20 RL+GNN解决人员排班问题时梯度消失
- ¥15 统计大规模图中的完全子图问题
- ¥15 使用LM2596制作降压电路,一个能运行,一个不能
- ¥60 要数控稳压电源测试数据
- ¥15 能帮我写下这个编程吗
- ¥15 ikuai客户端l2tp协议链接报终止15信号和无法将p.p.p6转换为我的l2tp线路