[英]Disassembling a simple C++ program
我有一个简单的C ++程序:
#include <iostream>
using namespace std;
int main(){
string s;
cin >> s;
if (s == "almafa")
cout << "ok";
}
在gdb中,我反汇编main并启动程序,输入“ testing”作为输入,并在比较0x0000000000400bb7处停止:
0x0000000000400bab <+53>: lea -0x40(%rbp),%rax
0x0000000000400baf <+57>: mov $0x400d24,%esi
0x0000000000400bb4 <+62>: mov %rax,%rdi
0x0000000000400bb7 <+65>: callq 0x400c6a <bool std::operator==<char, std::char_traits<char>, std::allocator<char> >(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> > const&, char const*)>
我检查了esi和rdi寄存器:
(gdb) x/s $esi
0x400d24: "almafa"
(gdb) x/s $rdi
0x7fffffffddc0: "\320\335\377\377\377\177"
rdi寄存器中有什么? 我希望它将包含我的输入。
rdi是指向std::string
对象的指针。
请注意,函数调用是对使用const char *
参数的operator==
进行的。
std::string
类定义一个带const char *
参数的operator==
,这就是这里要调用的内容,其中rdi指向std::string
对象的内存表示形式,并且参数位于esi中。
rdi寄存器中有什么? 我希望它将包含我的输入。
这不是您的输入。 您的输入存储在std::string
对象中,这就是这里指向的内容。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.