亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

匯編 JMP使用詳解

 更新時間:2020年02月03日 10:28:11   作者:極客創(chuàng)想  
這篇文章主要介紹了匯編 JMP使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

匯編 JMP 詳解關鍵詞說明

RVA: 相對虛擬地址(Relative Virtual Address),在內存中相對于PE文件裝入地址的偏移位置,是一個相對地址。

JMP 的 3 種類型

  • 短跳轉(Short Jmp,只能跳轉到256字節(jié)的范圍內),對應機器碼:EB
  • 近跳轉(Near Jmp,可跳至同一段范圍內的地址),對應機器碼:E9
  • 遠跳轉(Far Jmp,可跳至任意地址),對應機器碼: EA

短跳轉 和 近跳轉 指令中包含的操作數都是相對于(E)IP的偏移。

遠跳轉指令中包含的是目標的絕對地址。

所以短/近跳轉會出現跳至同一目標的指令機器碼不同,不僅會不同,而且應該不同。

而遠跳轉中包含的是絕對地址,因此轉移到同一地址的指令機器碼相同 。

至此,我們知道了跳轉指令所對應的機器碼根據E(IP)計算出來的,那到底是怎么計算的呢?

JMP 目標地址計算方式

目標地址 = 當前指令地址 + 指令長度 + RVA

舉例說明

如圖: 想要從 001392DB 處跳轉到 001392E1 這個地址,那么E9后面應該跟多少呢?

RVA = 001392E1 - 001392DB - 5

在計算機中使用上面的公式計算結果就是 RVA = 1 所以后面應該是跟 E9 01 00 00 00
其中 5 是指令長度 E9 后面需要跟 4 字節(jié)的地址,所以指令(1)+地址(4) = 5

ps: 如果計算結果是負數,則數值后面應該用 FF 填充,如負一則應該用 E9 01 FF FF FF

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 匯編語言系列之匯編實現簡單數學運算

    匯編語言系列之匯編實現簡單數學運算

    這篇文章主要介紹了匯編語言系列之匯編實現簡單數學運算的思路詳解,本文給大家列出了兩種算術運算的代碼,設計思路給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11
  • 常用的匯編指令與技巧(收藏)

    常用的匯編指令與技巧(收藏)

    這篇文章主要介紹了常用的匯編指令與技巧,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • 匯編基礎教程段的定義應用詳解

    匯編基礎教程段的定義應用詳解

    這篇文章主要為大家介紹了匯編基礎教程段的基本定義與應用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-11-11
  • UEFI開發(fā)實戰(zhàn)用戶交互界面基礎說明

    UEFI開發(fā)實戰(zhàn)用戶交互界面基礎說明

    這篇文章主要為大家介紹了UEFI開發(fā)實戰(zhàn)用戶交互界面的基礎說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • 純匯編實現打飛機小游戲的示例代碼

    純匯編實現打飛機小游戲的示例代碼

    這篇文章主要介紹了純匯編實現打飛機小游戲的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-01-01
  • 淺析ELF轉二進制允許把 Binary 文件加載到任意位置

    淺析ELF轉二進制允許把 Binary 文件加載到任意位置

    本文通過 eip + 偏移地址 實現了運行時計算數據地址,不再需要把 Binary 文件裝載到固定的位置。本文通過實例代碼給大家介紹的非常詳細,需要的朋友參考下吧
    2020-02-02
  • 8086匯編開發(fā)環(huán)境搭建和Debug模式介紹(圖文詳解)

    8086匯編開發(fā)環(huán)境搭建和Debug模式介紹(圖文詳解)

    這篇文章主要介紹了8086匯編開發(fā)環(huán)境搭建和Debug模式介紹,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-01-01
  • VScode配置8086匯編環(huán)境的過程解析

    VScode配置8086匯編環(huán)境的過程解析

    這篇文章主要介紹了VScode配置8086匯編環(huán)境的過程解析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Go 中的循環(huán)是如何轉為匯編的(方法詳解)

    Go 中的循環(huán)是如何轉為匯編的(方法詳解)

    這篇文章主要介紹了Go 中的循環(huán)是如何轉為匯編的,本文通過循環(huán)的匯編代碼給大家講解的非常詳細,代碼簡單易懂,非常不錯,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • 從Go匯編角度解讀for循環(huán)的問題

    從Go匯編角度解讀for循環(huán)的問題

    Go常用的遍歷方式有兩種:for和for-range。這篇文章主要介紹了從Go匯編角度解讀for循環(huán)的兩個疑點,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02

最新評論