欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C/C++程序鏈接與反匯編工具objdump的使用介紹

 更新時(shí)間:2023年02月03日 15:36:04   作者:水火汪  
這篇文章主要介紹了C/C++程序鏈接與反匯編工具objdump的使用,程序構(gòu)建過(guò)程的第二個(gè)階段就是鏈接,鏈接過(guò)程輸入的是目標(biāo)文件的集合。每個(gè)目標(biāo)文件可以被看作單個(gè)源代碼文件的二進(jìn)制存儲(chǔ)版本

程序構(gòu)建過(guò)程的第二個(gè)階段就是鏈接,鏈接過(guò)程輸入的是目標(biāo)文件的集合。每個(gè)目標(biāo)文件可以被看作單個(gè)源代碼文件的二進(jìn)制存儲(chǔ)版本,需要為程序內(nèi)存映射提供各種各樣的節(jié)(代碼.text 初始化數(shù)據(jù).data 未初始化數(shù)據(jù).bss 和只讀數(shù)據(jù).rdata),鏈接器的最終任務(wù)是將獨(dú)立的節(jié)組合成最終的程序內(nèi)存映射節(jié),與此同時(shí)解析所有的引用。

鏈接階段

鏈接過(guò)程包括一系列階段(重定位、解析引用),接下來(lái)我們介紹這些階段。

1.重定位

鏈接過(guò)程的第一個(gè)階段僅僅進(jìn)行拼接,其過(guò)程是將分散在單獨(dú)目標(biāo)文件中不同類型的節(jié)拼接到程序內(nèi)存映射節(jié)中。

如圖,為了完成任務(wù),需要將之前預(yù)留的空間,也就是節(jié)中從0開始的地址范圍轉(zhuǎn)換成最終程序內(nèi)存映射中更具體的地址范圍。

2.解析引用

現(xiàn)在我們來(lái)看鏈接過(guò)程中最難的部分,將節(jié)的地址范圍線性地轉(zhuǎn)換成程序內(nèi)存映射地址范圍。相比來(lái)說(shuō),更艱巨的任務(wù)在于為不同的部分的代碼建立關(guān)聯(lián),使得程序成為一個(gè)整體。

function.h代碼:

#pragma once
#define FIRST_OPTION
#ifdef FIRST_OPTION
#define MULTIPLIER (3.0)
#else
#define MULTIPLIER (2.0)#endif
float add_and_multiply(float x,float y);

function.c

//#include "function.h"
int nCompletionStatus = 0;
float add(float x,float y)
{
   float z = x + y;
   return z;
}
float add_and_multiply(float x,float y)
{
   float z = add(x,y);
   z *= 3;
   return z;
}

main.c

#include "function.h"
extern int nCompletionStatus;
int main(int argc,char* argv[])
{
    float x = 1.0;
    float y = 5.0;
    float z;
    z= add_and_multiply(x,y);
    nCompletionStatus =1;
    return 0;
}

在上例代碼中

  • add_and_multiply 函數(shù)調(diào)用add函數(shù),這兩個(gè)函數(shù)在同一個(gè)源代碼文件中,這種情況下,函數(shù)add的內(nèi)存映射地址是一個(gè)已知量,會(huì)被擴(kuò)展成其對(duì)與function.o中代碼節(jié)起始地址的相對(duì)偏移。
  • main函數(shù)會(huì)調(diào)用add_and_multiply函數(shù),并同時(shí)引用外部變量nCompletionStatus,這個(gè)時(shí)候問題就出現(xiàn)了--我們不知道它們的實(shí)際程序內(nèi)存地址,實(shí)際上編譯器會(huì)假定這些符號(hào)未來(lái)會(huì)在進(jìn)程內(nèi)存映射中存在,但是,直到生成完整內(nèi)存映射之前,這兩個(gè)引用會(huì)一直被當(dāng)成未解析引用。

該問題如圖描述:

function.o

main.o

為了解決這類問題,我們需要在鏈接階段就對(duì)這些引用進(jìn)行解析,此時(shí)鏈接器需要:

  • 檢查拼接到程序內(nèi)存映射中的節(jié)
  • 找出那些部分代碼產(chǎn)生了外部調(diào)用
  • 計(jì)算該引用的精確地址(在內(nèi)存映射中的地址)
  • 最后,將機(jī)器指令中的偽地址替換成程序內(nèi)存映射的實(shí)際地址,這樣就完成了引用的解析。

3.鏈接示例

程序內(nèi)存映射圖

gcc -c function.c main.c
gcc function.o main.o -o demoApp

反匯編main.o文件

objdump -D -M intel main.o

劃紅線的是跳轉(zhuǎn)自身,是因?yàn)殒溄悠鞑恢篮瘮?shù)的地址。先用偽地址代替。

反匯編demoApp

objdump -D -M intel demoApp

畫紅線的位置分別是add_and_multiply 地址為11aa 和nCompletionStatus的地址。

執(zhí)行下面命令查看,看到nCompletionStatus地址為4014.

objdump -x -j .bss demoapp

到此這篇關(guān)于C/C++程序鏈接與反匯編工具objdump的使用介紹的文章就介紹到這了,更多相關(guān)C++程序鏈接內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • OpenCV實(shí)現(xiàn)圖像距離變換

    OpenCV實(shí)現(xiàn)圖像距離變換

    這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)圖像距離變換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C語(yǔ)言實(shí)現(xiàn)掃雷小游戲的示例代碼

    C語(yǔ)言實(shí)現(xiàn)掃雷小游戲的示例代碼

    這篇文中主要為大家詳細(xì)介紹了如何利用C語(yǔ)言實(shí)現(xiàn)經(jīng)典的掃雷小游戲。掃雷小游戲主要是利用字符數(shù)組、循環(huán)語(yǔ)句和函數(shù)實(shí)現(xiàn),感興趣的小伙伴可以了解一下
    2022-10-10
  • C語(yǔ)言入門篇--初識(shí)指針和指針變量

    C語(yǔ)言入門篇--初識(shí)指針和指針變量

    本篇文章是基礎(chǔ)篇,適合c語(yǔ)言剛?cè)腴T的朋友,本文對(duì)初識(shí)c語(yǔ)言的指針和指針變量做了簡(jiǎn)單的分析,幫助大家快速入門c語(yǔ)言的世界,更好的理解c語(yǔ)言
    2021-08-08
  • 最新評(píng)論