反汇编基础-数据类型以及C++引用、指针反汇编后的概括
生活随笔
收集整理的這篇文章主要介紹了
反汇编基础-数据类型以及C++引用、指针反汇编后的概括
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
反匯編中的數據類型
在匯編中,無論是字符串類型,整數類型還是其他類型都只有2個關鍵單位,地址、長度
【注意:LEA為取地址指令】
引用和指針的匯編代碼:
引用并不會影響程序的執行效率,使用引用又比指針多了編譯器的檢測
所以在編寫C++程序時應該拋棄指針,擁抱引用。
在匯編中,無論是字符串類型,整數類型還是其他類型都只有2個關鍵單位,地址、長度
【注意:LEA為取地址指令】
引用和指針的匯編代碼:
引用并不會影響程序的執行效率,使用引用又比指針多了編譯器的檢測
所以在編寫C++程序時應該拋棄指針,擁抱引用。
const為編譯期檢查
下面先來看一個C++源碼:
#include <stdio.h>int main(){char *p_str = "CSDN IT1995";char arr_str[] = "CSDN IT1995";int n = 100;int *p_n = &n;int &r_n = n;#define num 100n = num;const int c_i = 100;return 0; }其中Main函數內對應的反匯編代碼如下:
ptr -- pointer (指針)的縮寫
第一個char *p_str="CSDN IT1995"
這里是把 2F58A8h這個地址,給了ptr[p_str]這個地址指向的指,說明這個是一個指針;
第二個char arr_str[]="CSDN IT1995";
他的反匯編是如上,這個有幾個知識點:
DS(Data Segment):數據段寄存器,還有ds:[xxxx]
ds:[bx+16]指向一個內存地址
ds數據段寄存器是,[bx+16]是它的偏移地址,[段地址*16+偏移地址]得到一個20位的物理地址即ds:[bx+16]真正指向的地址
此處其實就是4個字節的,四個字節往EDP放,這里可以知道,數組是連續的。
第三個:int n=100;
這里,100的十六進制是64
第四個:int *p_n=&n;
這里要注意:LEA就是目標地址傳送指令: 將一個地址指針寫入到指定的寄存器 把地址寫到[p_n]這個指針指向的值里面。第五個是int &r_n=n;
這里可以看到,指針與引用沒有雞毛的區別(從反匯編來看,在C++書上,我們都知道,空間大小,編譯時還是有差別的),所以要多用引用
第六個#define num 100;
n=num;這里面和第七個const int c_i=100在反編譯里面的代碼并沒有什么區別
總結
以上是生活随笔為你收集整理的反汇编基础-数据类型以及C++引用、指针反汇编后的概括的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C++|Qt工作笔记-杀死进程(Linu
- 下一篇: 反汇编基础-加法的求值过程(各种类型)