指標變數所佔記憶體

2021-08-21 16:52:18 字數 1567 閱讀 2366

**:

應該說這是乙個非常基礎的問題,教科書上說指標大小和機器字長相同,即32位機指標長度為4位元組!但是對不對呢?為什麼是這樣?

搜了一下相關資料。。。居然發現回答不統一,很多人也同樣是糊里糊塗。

字長:在同一時間中處理二進位制數的位數叫字長。通常稱處理字長為8位資料的cpu叫8位cpu,32位cpu就是在同一時間內處理字長為32位的二進位制資料。二進位制的每乙個0或1是組成二進位制的最小單位,稱為乙個位元(bit)。

一般說來,計算機在同一時間內處理的一組二進位制數稱為乙個計算機的「字」,而這組二進位制數的位數就是「字長」。字長與計算機的功能和用途有很大的關係,是計算機的乙個重要技術指標。字長直接反映了一台計算機的計算精度,為適應不同的要求及協調運算精度和硬體造價間的關係,大多數計算機均支援變字長運算,即機內可實現半字長、全字長(或單字長)和雙倍字長運算。在其他指標相同時,字長越大計算機的處理資料的速度就越快。早期的微機字長一般是8位和16 位,386以及更高的處理器大多是32位。目前市面上的計算機的處理器大部分已達到64位。

字長由微處理器(cpu)對外資料通路的資料匯流排條數決定。

定址空間:定址空間一般指的是cpu對於記憶體定址的能力。cpu最大能查詢多大範圍的位址叫做定址能力,cpu的定址能力以位元組為單位 (位元組是最小可定址單位),如32位定址的cpu可以定址2的32次方大小的位址也就是4g,這也是為什麼32位定址的cpu最大能搭配4g記憶體的原因,再多的話cpu就找不到了。

這裡cpu的定址位數是由位址匯流排的位數決定,32位cpu的定址位數不一定是32位,因為32位cpu中32的意義為字長。

有關定址範圍計算解釋,對於32位定址的cpu,其位址值為32位的二進位制數,所以可以表示的最大位址為2的32次方(即4g,最大記憶體空間為4gb,這裡g表示數量、gb表示容量)。同時我們不難看出,乙個指標的值就是乙個32位的二進位制數,32位對應4位元組(byte)。所以,指標的大小實際上是由cpu的定址位數決定,而不是字長

再來分析一下如下的情況:

32位處理器上32位作業系統的32位編譯器,指標大小4位元組。

32位處理器上32位作業系統的16位編譯器,指標大小2位元組。  

32位處理器上16位作業系統的16位編譯器,指標大小2位元組。

16位處理器上16位作業系統的16位編譯器,指標大小2位元組。

這從結果看起來指標的大小和編譯器有關??

實際不是這樣的,有這樣的結果是因為以上幾種情況,處理器當前執行模式的定址位數是不一樣的,如下:

intel 32位處理器32位執行模式,邏輯定址位數32,指標也就是32位,即4個位元組

intel 32位處理器16位虛擬機器執行模式,邏輯定址位數16,指標也就是16位,即2個位元組

編譯器的作用是根據目標硬體(即cpu)的特性將源程式編譯為可在該硬體上執行的目標檔案。如果乙個編譯器支援某32位的cpu,那麼它就可以將源程式編譯為可以在該cpu上執行的目標檔案。該源程式中指標大小也會被編譯器根據該cpu的定址位數(如32位)編譯選擇為4位元組。

綜上可得:指標大小是由當前cpu執行模式的定址位數決定!

指標所佔記憶體剖析

指標的長度並非跟計算機字長有關,準確地說,是跟段大小和編譯模式有關。你所看到的16位cpu指標兩個位元組 32位cpu指標四個位元組其實是一種錯覺。指標所指向的實體,無非在 code data bss const和stack段,指標的值是這些段的段內偏移,段內偏移結合段暫存器的段值 實模式 或者段描...

指標變數在記憶體中佔 指標在系統記憶體中所佔的位元組數

sizeof 的特點 printf d int printf d float printf d double 其結果為 4 4 4 這就是面試的時候問你,指標在記憶體中佔多少個位元組?這就是個問題不是簡單的2,4,甚至8個位元組 回答 指標在記憶體中所在的位元組數是由系統的定址能力決定的,定址能力就...

指標變數記憶體

1 指標不同於一般變數,存的是變數的位址,在同一架構下位址長度都是相同的 cpu的最大定址記憶體空間 所以不同型別的指標長度都一樣 你輸出的4 4 4,說明指標長度為4位元組 可以記錄的位址範圍是0x00000000 0xffffffff,這個範圍才是指標變數的值 比如說乙個char 1位元組,可以...