hejehshsh 2021-07-06 08:05 采纳率: 100%
浏览 25
已采纳

关于 过程调用和返回 的 反汇编代码 的一些小疑问

img

img

img

题中调用first函数里面传参写的是(long x),还有last(long u,long v)这不都应该是传值吗?传值应该不改变原来调用函数里参数的值啊。
最后在return的时候,除了%rax寄存器,其余的不都应该free掉了吗?
但是答案里,表中%rdi和%rsi寄存器在return后,这些值还在……
拜托🙏各位大佬帮忙解答,谢谢

  • 写回答

2条回答 默认 最新

  • 二当家的白帽子 后端领域优质创作者 2021-07-06 11:25
    关注

    在进入函数的时候,会先把寄存器传来的参数都放入栈的,相当于做了拷贝,否则如果你在main函数把所有寄存器用了个遍,别的函数不是永远不能再使用寄存器,那就完全无法执行了?寄存器是一起用的,每个函数里如果会修改寄存器的值,应该需要先将寄存器的值入栈,函数返回前再将寄存器的值出栈复原,这些操作都是c语言编译器自动补充进去的,不需要写c语言时候手动写。虽然寄存器的值可能变了,但是对于c语言的人是透明的,除非内联汇编,否则你并不能直接操作寄存器。你截图的内容只是反汇编的部分内容,并不是全部,你自己反汇编看看就会明白的,里面会有一些保存寄存器的值和还原寄存器的值的操作,可能是调用函数负责,也可能是被调用的函数负责。

    如果是调用方维护寄存器的值,那么被调用函数在返回前就不需要还原寄存器,但是调用方在函数返回后除了return的那个寄存器,也就是rax,其他寄存器的值也不该直接使用。这些不需要c语言的编程人考虑,应该是写c编译器的人考虑

    img

    img

    free掉只是你不能再用了,也不再占用内存空间,不代表值一定被抹掉。就像硬盘删除文件,一般不会把文件内容抹掉,正常情况删除你就不能访问了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
  • ¥50 我撰写的python爬虫爬不了 要爬的网址有反爬机制
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥120 计算机网络的新校区组网设计
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等