当前位置: 首页 > news >正文

专门做库存的网站深圳沙头网站建设

专门做库存的网站,深圳沙头网站建设,c程序设计教学网站怎么做,专题网站怎么做vs2022 x64 C/C和汇编混编 遇到的坑 遇到的问题二、问题复现1.出错代码2.问题分析2.1 堆栈对齐问题 3.解决方案 总结奇数和偶数个寄存器的影响为什么 sub rsp, 8 对奇数个寄存器有用?结论 遇到的问题 0x00007FFFFAE24A29 (msvcp140.dll)处(位于 TestCompileConsole…

vs2022 x64 C/C++和汇编混编 遇到的坑

  • 遇到的问题
  • 二、问题复现
    • 1.出错代码
    • 2.问题分析
      • 2.1 堆栈对齐问题
    • 3.解决方案
  • 总结
      • 奇数和偶数个寄存器的影响
      • 为什么 `sub rsp, 8` 对奇数个寄存器有用?
      • 结论


遇到的问题

0x00007FFFFAE24A29 (msvcp140.dll)处(位于 TestCompileConsoleApp.exe 中)引发的异常: 0xC0000005: 读取位置 0xFFFFFFFFFFFFFFFF 时发生访问冲突。
查阅资料发现:异常 0xC0000005: Access Violation 表示程序试图访问一个无效的内存地址。在你的情况下,读取地址 0xFFFFFFFFFFFFFFFF 发生了访问冲突。这通常意味着你试图访问一个无效的指针或未初始化的指针。

— # 一、pandas是什么?
示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。

二、问题复现

1.出错代码

代码如下(示例):

capp procsub rsp, 28h             ; 为局部变量和寄存器保存空间; 保存所有需要的寄存器push raxpush rcxpush rdxpush r8push r9push r10push r11; 自定义代码mov rcx, 10              ; 将参数传递给RCX寄存器call hookFunc            ; 调用hookFunc函数; 恢复所有寄存器pop r11pop r10pop r9pop r8pop rdxpop rcxpop raxadd rsp, 28h             ; 恢复堆栈指针ret
capp endp

2.问题分析

2.1 堆栈对齐问题

在 x64 汇编中,函数调用时堆栈指针(RSP)必须是 16 字节对齐的。如果你在调用函数前通过 push 指令保存了寄存器,堆栈指针会减少 8 个字节,这可能会导致堆栈不对齐。

3.解决方案

 capp procsub rsp, 28h             ; 为局部变量和寄存器保存空间; 保持堆栈对齐sub rsp, 8; 保存寄存器push raxpush rcxpush rdxpush r8push r9; 调用你的函数mov rcx, 10call hookFunc; 恢复寄存器pop r9pop r8pop rdxpop rcxpop rax; 恢复堆栈对齐add rsp, 8add rsp, 28h             ; 恢复堆栈指针ret
capp endp

如果保存寄存器的数量是奇数个,可以通过手动调整来保证堆栈对齐。例如,使用 sub rsp, 8 手动调整堆栈指针,使其对齐到 16 字节。


总结

在 x64 汇编中,堆栈的对齐要求是函数调用时堆栈指针(RSP)必须是 16 字节对齐的。为了确保这一点,我们需要根据保存的寄存器数量来决定是否要调整堆栈指针。

奇数和偶数个寄存器的影响

  1. 奇数个寄存器:

    • 每个 push 指令都会将堆栈指针减少 8 个字节
    • 如果你保存奇数个寄存器(例如1、3、5个寄存器),堆栈指针会减少一个不是 16 字节的倍数的值(如 8、24、40 个字节)。
    • 这时,堆栈指针的对齐就会被破坏,从而导致后续函数调用时堆栈不是 16 字节对齐的。
  2. 偶数个寄存器:

    • 如果你保存偶数个寄存器(例如 2、4、6 个寄存器),堆栈指针减少的值会是 16 字节的倍数(如16、32、48个字节)。
    • 在这种情况下,堆栈指针的对齐不会被破坏,因此不需要进行额外的调整。

为什么 sub rsp, 8 对奇数个寄存器有用?

当你保存奇数个寄存器时,堆栈指针被推到一个不是 16 字节对齐的地址。通过在保存寄存器之前执行 sub rsp, 8,你可以先手动将堆栈指针调整到一个不对齐的状态,接下来每次 push 操作都会在最终使堆栈指针回到对齐的状态。

具体来说:

  • sub rsp, 8 手动将 RSP 移动 8 个字节,使其暂时不对齐。
  • 然后,每次 push 操作都会进一步移动 RSP 8 个字节。
  • 如果你总共 push 奇数个寄存器,RSP 将恢复到对齐的状态。

结论

  • 奇数个寄存器: 你需要通过 sub rsp, 8 手动调整堆栈指针,以确保保存和恢复寄存器后堆栈指针是 16 字节对齐的。
  • 偶数个寄存器: 由于堆栈指针在保存和恢复寄存器前后仍然是 16 字节对齐的,所以不需要进行额外的调整。

这个技巧帮助你在函数调用时确保堆栈的对齐性,从而避免潜在的问题。

http://www.yayakq.cn/news/217139/

相关文章:

  • 做网站所需要的技术企业文化网站建设
  • 怎么自己编写网站杭州首传网站建设公司怎么样
  • 怎样自己创造网站网站后台都有哪些
  • 凡科这样的建站网站权威发布
  • 嘉兴网站建设有前途吗网站开发保密合同
  • 微信公众好第三方网站怎么做网站开发哪一门语言更快
  • 苏州h5建站百度应用商店
  • 建站之星破解版手机什么是网络营销4c理论
  • 网站制作教程下载全国企业信息公示查询系统官网
  • 网站百度云链接模板网的图片侵权
  • 安徽住房建设厅网站鲜花销售网站模板
  • 周到的网站建站好用的免费国内ip代理
  • 北京医疗网站建设公司排名杨凌做网站的
  • 内网做网站需要空间吗做网站首页ps中得多大
  • wordpress回收站+恢复网页.网站.主页.网址.域名有什么联系
  • 网站排名如何提升沈阳什么行业做网站的最多
  • 网站建设新闻如何更新网络营销与策划实践报告
  • 网站建设产品培训全球最大的外贸平台
  • 清溪东莞网站建设最新赚钱项目发布平台
  • 凡科网站空间慢wordpress 调用描述
  • 网站开发平台有哪些南宁网站排名外包
  • 太原住房与城乡建设厅网站关键词优化除了做网站还有什么方法
  • 临泽县建设局网站惠阳网站优化
  • 自己做的网站能赚钱吗gif网站素材
  • 网站各页面wordpress 关闭某个插件的更新
  • 建设班级网站 沟通无限教育类网站开发需求说明书
  • 图书馆网站建设与评价研究做百度移动网站点
  • 主题资源网站制作平台notepad做网站
  • 网站运维滁州网站建设信息推荐
  • 开发一套网站多少钱想要一个免费的网站