我在VS使用反汇编看到的依然是32位汇编。

1. 寄存器

  • 64位有16个寄存器,32位只有8个。但是32位前8个都有不同的命名,分别是e _ ,而64位前8个使用了r代替e,也就是r _。e开头的寄存器命名依然可以直接运用于相应寄存器的低32位。而剩下的寄存器名则是从r8 - r15,其低位分别用d,w,b指定长度。
  • 32位使用栈帧来作为传递的参数的保存位置,而64位使用寄存器,分别用rdi,rsi,rdx,rcx,r8,r9作为第1-6个参数。rax作为返回值
  • 64位没有栈帧的指针,32位用ebp作为栈帧指针,64位取消了这个设定,rbp作为通用寄存器使用
  • 64位支持一些形式的以PC相关的寻址,而32位只有在jmp的时候才会用到这种寻址方式。

2. 汇编指令

64位(新增)汇编指令的不同

mov指令和push pop扩展了movq系列的mov和pushq以及popq用来操作quad word。

注意:movabsq不是32位的扩展,是纯新增的指令。用来将一个64位的字面值直接存到一个64位寄存器中。因为movq只能将32位的值存入,所以新增了这样一条指令。

顺带提一个小问题,64位的汇编代码在ret之前可能会加一句rep,这里的rep没有实际意义,只是出于amd处理器的原因,避免jmp所到达的地方直接就是ret,这样会使得处理器运行更快一些。

3. 过程(跳转指令)调用不同

  • 参数通过寄存器传递(见前文)
  • callq 在栈里存放一个8位的返回地址
  • 许多函数不再有栈帧,只有无法将所有本地变量放在寄存器里的才会在栈上分配空间。
  • 函数可以获取到栈至多128字节的空间。这样函数就可以在不更改栈指针的情况下在栈上存储信息(也就是说,可以提前用rsp以下的128字节空间,这段空间被称为red zone,在x86-64里,时刻可用)
  • 不再有栈帧指针。现在栈的位置和栈指针相关。大多数函数在调用的一开始就分配全部所需栈空间,之后保持栈指针不改变。
  • 一些寄存器被设计成为被调用者-存储的寄存器。这些必须在需要改变他们值的时候存储他们并且之后恢复他们。

4. 参数传递不同

  • 6个寄存器用来传递参数(见前文)(rdi,rsi,rdx,rcx,r8,r9)
  • 剩下的寄存器按照之前的方式传递(不过是与rsp相关了,ebp不再作为栈帧指针,并且从rsp开始第7个参数,rsp+8开始第8个,以此类推)
  • 调用时,rsp向下移动8位(存入返回地址),寄存器参数无影响,第7个及之后的参数现在则是从rsp+8开始第7个,rsp+16开始第8个,以此类推。

5. 栈帧的不同

很多情况下不再需要栈帧,比如在没有调用别的函数,且寄存器足以存储参数,那么就只需要存储返回地址即可。 
需要栈帧的情况:

  • 本地变量太多,寄存器不够
  • 一些本地变量是数组或结构体
  • 函数使用了取地址操作符来计算一个本地变量的地址
  • 函数必须用栈传送一些参数给另外一个函数
  • 函数需要保存一些由被调用者存储的寄存器的状态(以便于恢复)

但是现在的栈帧经常是固定大小的,在函数调用的最开始就被设定,在整个调用期间,栈顶指针保持不变,这样就可以通过对其再加上偏移量来对相应的值进行操作,于是EBP就不再需要作为栈帧指针了。

虽然很多时候我们认为没有“栈帧”,但是每次函数调用都一定有一个返回地址被压栈,我们可以也认为这一个地址就是一个“栈帧”,因为它也保存了调用者的状态。

32位、64汇编区别相关推荐

  1. 64位windows与32位windows的区别

    64位windows与32位windows的区别 2010-07-19 15:46 64位windows与32位windows的区别 http://www.zeroplace.cn/article.a ...

  2. 【Android 逆向】IDA 工具使用 ( IDA 32 位 / 64 位 版本 | 汇编代码视图 IDA View-A | 字符串窗口 Strings window )

    文章目录 一.IDA 32 位 / 64 位 版本 二.汇编代码视图 IDA View-A 三.字符串窗口 Strings window 一.IDA 32 位 / 64 位 版本 IDA 安装完毕后 ...

  3. 64位内核第一讲,和32位内核的区别

    64位内核第一讲,和32位内核的区别 双击调试配置请查看 连接: https://www.cnblogs.com/aliflycoris/p/5877323.html 一丶编译的区别. 首先,还是使用 ...

  4. 64位和32位有什么区别?到底哪个更快?——硬核科普

    原文链接:联想商用服务----64位和32位有什么区别?到底哪个更快?--硬核科普 32位和64位到底指什么? 下载 Windows 操作系统,会区分 X 64 和 X 86 版本(一般 X 86 是 ...

  5. int 字节在32位 64位系统的区别

    一)64位系统和32位有什么区别? 1.64bit CPU拥有更大的寻址能力,最大支持到16GB内存,而32bit只支持4G内存 2.64位CPU一次可提取64位数据,比32位提高了一倍,理论上性能会 ...

  6. 32位/64位软件和系统的区别

    32位/64位软件和系统的区别 win7 x86就是win7 32位系统 win7 x64就是win7 64位系统(一般需要电脑运行存储>4GB)

  7. dll文件32位64位检测工具以及Windows文件夹SysWow64的坑

    自从操作系统升级到64位以后,就要不断的需要面对32位.64位的问题.相信有很多人并不是很清楚32位程序与64位程序的区别,以及Program Files (x86),Program Files的区别 ...

  8. 让使用SQLite的.NET应用自适应32位/64位系统

    Windows 7 64 bit(刚扩到4G内存,果断换64位的,那速度杠杠的) Microsoft Visual Studio 2010 Ultimate 32bit(在64位系统里运行正常) sq ...

  9. 服务器优盘启动安装win7系统教程,晨枫u盘启动工具安装原版Win7的两种方法(32位64位系统通用)...

    安装原版Win7两类方法 第一类方法(32位64位系统通用): 具体步骤: [1]先使用晨枫U盘启动制作工具制作完启动U盘(参照制作教程). [1]找到Windows7系统的iso镜像,用UltraI ...

  10. oracle odp版本,oracle odp.net 32位/64位版本的问题

    如果你的机器上安装了odp.net,且确信machine.config也有类似以下结节:(64位+.net 4.0环境下,machine.config可能会有4份,分别对应于.net2.0/4.0的3 ...

最新文章

  1. 斯坦福-随机图模型-week2.1_
  2. css中属性兼容性写法,CSS3兼容属性和标准属性的书写顺序
  3. mysql导入wordpress_WordPress搬家,导入mysql出错的解决方法 - 老牛博客
  4. PE文件RV转FOA及FOA转RVA
  5. Eclipse EGit插件安装使用记录
  6. 《TCP/IP详解》读书笔记
  7. python 近期用到的基础知识汇总(四)
  8. Shiro-从数据表中初始化资源和权限
  9. Python爬虫书籍分享
  10. 二进制颜色查询对照表
  11. sqlplus 命令导入数据文件
  12. python中ADSL拨号
  13. js批量生成条形码制作前端标签打印工具
  14. android 模拟器介绍
  15. 5分钟成为车联网专家 | 全球首个C-V2X车联网城市级规模示范应用
  16. 深信服安全运营工程师一面经验+二面经验
  17. 使用Google语音识别引擎(Google Speech API)
  18. python禅语_42:对象、类、以及从属关系
  19. HDU-4544-湫湫系列故事——消灭兔子--贪心+优先队列
  20. 上海大专计算机专业排名,2019上海软科世界一流学科排名计算机科学与工程专业排名乔治华盛顿大学排名第301-400...

热门文章

  1. Ngs File Type Transfer
  2. macOS Big Sur Wi-Fi 网络无法连接如何解决
  3. tomcat 优化_浅谈Tomcat服务器优化方法
  4. python使用opencv_教你快速使用OpenCV/Python/dlib進行眨眼檢測識別!
  5. react中@withrouter_为什么 withRouter 高阶组件应该 处于最外层?
  6. php取结果集,php获取数据库结果集方法(推荐)
  7. vue router 的两种路由模式hash与history的区别
  8. Java笔记-JDK搭建WebService客户端其他调用方法
  9. Arduino笔记-温度传感器的使用
  10. django 指定模型排除的字段