新手刚开始自学,求大佬给注释一下,越详细越好!
call 0x401930 <__main>
0x0040134E mov DWORD PTR [esp+0x8],0x7
0x00401356 lea eax,[esp+0x8]
0x0040135A mov DWORD PTR [esp+0xc],eax
0x0040135E mov eax,DWORD PTR [esp+0xc]
0x00401362 mov eax,DWORD PTR [eax]
0x00401364 lea edx,[eax+0x1]
0x00401367 mov eax,DWORD PTR [esp+0xc]
0x0040136B mov DWORD PTR [eax],edx
0x0040136D mov eax,0x0
0x00401372 leave
这个是反汇编的吧
call 0x401930 调用_main
0x0040134E mov DWORD PTR [esp+0x8],0x7 将堆栈上相对0x8的存储地址指向的变量,赋值7(堆栈上存储的是局部变量,这里是指针)
0x00401356 lea eax,[esp+0x8] 将esp+0x8存入eax寄存器
0x0040135A mov DWORD PTR [esp+0xc],eax 再存入esp+0xc这个堆栈上存储变量所代表的地址指向的存储单元
0x0040135E mov eax,DWORD PTR [esp+0xc] 将其再存入eax
0x00401362 mov eax,DWORD PTR [eax] //将eax指向的内容作为指针,找到对应的存储,再存入eax,相当于二重指针
0x00401364 lea edx,[eax+0x1] //计算eax+0x1,存入edx
0x00401367 mov eax,DWORD PTR [esp+0xc] //将esp+0xc指向的内容,传入eax
0x0040136B mov DWORD PTR [eax],edx //将edx传入eax指向的存储单元
0x0040136D mov eax,0x0 将eax设置为0,如果函数返回,则返回值就是0
0x00401372 leave 退出