汇编代码疑问
在mac下,对c语言gcc的目标文件otool 获得反汇编结果,部分结果如下:
(__TEXT,__text) section
_main:
0000000100000ea0 pushq %rbp
0000000100000ea1 movq %rsp, %rbp
0000000100000ea4 subq $0x20, %rsp
关于第3行,subq $0x20, %rsp 我再网上查说,是为局部变量分配内存,但为什么是32字节呢?
这是固定的吗? 还是计算出来的,如果计算出来,是怎么计算的?c语言代码如下:
int golbal_var=3;
int golbao_var2;
int main()
{
//extern int extern_var ;
printf("extern var is:%d and its address is:%x\n",reall_extern_var,&reall_extern_var);
int auto_x=15,i=10;
//printf("%d, %d\n",&YES);
printf("%x\n",&auto_x);
static int static_var;
printf("%x\n",&static_var);
register int reg_var=0;
for(i=0; i<10; ++i){
reg_var++;
// printf("%d",®_var); 寄存器变量没有地址
}
return 0;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
这一句是为了局部变量分配内存的。具体分配多少这是编译器相关的,肯定比你需要的大。
你可以尝试一下使用个数组,让临时变量的总大小超过32,那么在这就会分配多于32字节了。
据我所知, 前三行的代码是压栈操作, 保持栈指针, 函数返回时再出栈.
对于x86-64系统来说,还要求rsp的地址是16个字节对齐的。