日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

深入浅出根据函数调用过程谈栈回溯原理

發布時間:2023/12/18 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 深入浅出根据函数调用过程谈栈回溯原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

???????????

? ? ? ? 通過分析函數調用過程的堆棧變化,可以看出在被調函數的EBP寄存器地址存放的是調用函數的EBP寄存器地址,EBP地址+4存放的是函數調用完成后的下一條指令存放地址,該指令的前一條指令則是調用函數的指令。說起來有點拗口,接下來代碼分析一下:

? ? ? ? 分析使用的源碼如下:

[cpp] view plaincopyprint?
  • int?_cdecl?FunA(int?a,?int?b)??
  • {??
  • ????int?d;??
  • ????d?=?a?+?b;??
  • ????return?d;??
  • }??
  • ??
  • int?_cdecl?FunB(int?a,?int?b)??
  • {??
  • ????return?FunA(a,?b);??
  • }??
  • ??
  • int?_cdecl?FunC(int?a,?int?b)??
  • {??
  • ????return?FunB(a,?b);??
  • }??
  • ??
  • int?_cdecl?main(int?argc,?char*?argv[])??
  • {??
  • ????int?r;??
  • ????r?=?FunC(2,?3);??
  • ????return?0;??
  • }??
  • int _cdecl FunA(int a, int b) {int d;d = a + b;return d; }int _cdecl FunB(int a, int b) {return FunA(a, b); }int _cdecl FunC(int a, int b) {return FunB(a, b); }int _cdecl main(int argc, char* argv[]) {int r;r = FunC(2, 3);return 0; }

    在函數FunA內的任意位置添加斷點,然后執行代碼,則會在該處停住,通過VS的cmd窗口分析步驟如下:

    1、? 查看寄存器值,得出EBP=0x002FF734

    2、? 根據該EBP,找到FuncA返回后的指令執行地址0x0005142B

    3、? 因為CALL函數執行的機器碼=call機器碼(1個字節)+函數地址(4個字節),得出call funcA這條指令的執行地址為0x00051426(0x0005142B-5)

    4、? 得出指令機器碼為e8 6b fc ff ff

    5、? 機器碼算出調用指令地址 0Xfffffc6B+5(五個字節)+0x00051426(call指令地址)=0x00051096

    6、? 查看0x00051096地址得出機器碼 e9 25 0300 00,該機器碼顯示為jmp指令

    7、 ?再通過計算0x000325+5+0x0005196=0x000513c0最終得出調用函數的地址。

    在VS2008窗口中分析命令如下:


    通過實際查看FunA的函數入口位置如下所示:


    ? ? ? ? 通過以上分析可以得出FunA函數的調用地址,但是整個過程是沒辦法知道函數的名稱的,知道函數名稱需要使用.pdb(symbol文件:在編譯過程中生成的符號文件)。這邊就不分析了。

    ? ? ? ? 所以通過EBP加函數返回的指令地址可以一步一步的回溯整個過程的函數調用關系,也就是所謂的棧回溯原理了。

    ? ? ? ? 好吧,原理歸原理,我們還是乖乖的命令窗口敲下>kb命令看看整個的函數調用過程吧。


    ? ? ? ? ?可以看出到后面VS也沒法知道整個系統的符號文件,只能給出一個地址。

    ? ? ? ? ?至此棧回溯原理分析結束,若有問題,請幫忙指出,不勝感激。  創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的深入浅出根据函数调用过程谈栈回溯原理的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。