qq_36316736
武志祥
2017-12-13 02:07
采纳率: 50%
浏览 1.0k
已采纳

汇编问题-本人刚开始自学求大佬帮忙?

新手刚开始自学,求大佬给注释一下,越详细越好!
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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • caozhy
    已采纳
     这个是反汇编的吧
    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 退出
    
    点赞 评论

相关推荐