64位Debug版本C++汇编代码函数开始结尾出现push rdi,pop rdi 作用
如上图一开始发现代码中单纯出现了push rdi,pop rdi 发现并没有什么实际用处很是困惑,之后选择放弃;然后又遇到了下图rep stosd看不懂,但是这两个问题碰到一起就很好解决了。
首先我们需要了解rep stosd是什么意思
该指令需要用到三个寄存器:ecx,eax,edi/rdi
作用是将eax的内容存储到edi指向的位置,每次将edi(取决于方向标志)递增或递减4个字节。 每次迭代ecx减1,并且当循环达到零时循环停止。(这里30h÷0Ch=48+12=4)
因此这两个结合到一起的作用便是初始化栈空间,这样就很好理解为啥注释上是保存环境了。
参考文章:
附:
万能的群友,问了NB,NB果然NB