在汇编中,许多函数都以下面的序言开头:
00000001004010e0: main(int, char**)+0 push %rbp
00000001004010e1: main(int, char**)+1 mov %rsp,%rbp
某些功能(如下所示)不会:
int MainEntry(){
MainEntry():
0000000100401104: MainEntry()+0 push %rbp
0000000100401105: MainEntry()+1 push %rbx
0000000100401106: MainEntry()+2 sub $0x48,%rsp
000000010040110a: MainEntry()+6 lea 0x80(%rsp),%rbp
vector<int> v;
0000000100401112: MainEntry()+14 lea -0x60(%rbp),%rax
0000000100401116: MainEntry()+18 mov %rax,%rcx
0000000100401119: MainEntry()+21 callq 0x100401b00 <std::vector<int, std::allocator<int> >::vector()>
return 0;
000000010040111e: MainEntry()+26 mov $0x0,%ebx
0000000100401123: MainEntry()+31 lea -0x60(%rbp),%rax
0000000100401127: MainEntry()+35 mov %rax,%rcx
000000010040112a: MainEntry()+38 callq 0x100401b20 <std::vector<int, std::allocator<int> >::~vector()>
000000010040112f: MainEntry()+43 mov %ebx,%eax
}
这是编译成这个的C ++代码:
int main(int c, char** args){
MainEntry();
return 0;
}
int MainEntry(){
vector<int> v;
return 0;
}
所以这是我的两个问题:
MainEntry
函数中,有push rbp
,然后是push rbx
。为什么rbx
被推入堆栈?sub $0x48,%rsp
会在堆栈上分配0x48 bytes
,并lea 0x80(%rsp),%rbp
向下移动0x80 bytes
并将其指定为基础。 rbp
哪里最终会在本地堆栈框架中结束?它是如何实现的?答案 0 :(得分:2)
1)rbx
被推入堆栈,因为调用约定表明它是在调用之间保留的。
2)此函数在没有帧指针的情况下编译。在没有帧指针的情况下进行编译时,rbp
只是另一个通用寄存器。
标题中的问题)该指令不存在。 push始终采用一个参数。也许你的意思是问为什么rbp
没有推动。答案是什么都没用,所以不需要任何指示来保存它。