整理自指標的大小到底是由誰決定?是多少?
首先,介紹幾個基本概念:
1、字長
:在同一時間中處理二進位制數的位數叫字長。通常稱處理字長為8位資料的cpu叫8位cpu,32位cpu就是在同一時間內處理字長為32位的二進位制資料。二進位制的每乙個0或1是組成二進位制的最小單位,稱為乙個位元(bit)。
一般說來,計算機在同一時間內處理的一組二進位制數稱為乙個計算機的「字」,而這組二進位制數的位數就是「字長」。字長與計算機的功能和用途有很大的關係, 是計算機的乙個重要技術指標。字長直接反映了一台計算機的計算精度,為適應不同的要求及協調運算精度和硬體造價間的關係,大多數計算機均支援變字長運算,
即機內可實現半字長、全字長(或單字長)和雙倍字長運算。在其他指標相同時,字長越大計算機的處理資料的速度就越快。早期的微機字長一般是8位和16 位,386以及更高的處理器大多是32位。目前市面上的計算機的處理器大部分已達到64位。
字長由微處理器(cpu)
對外資料通路的資料匯流排
條數決定。2、
最小可定址單位
:記憶體的最小可定址單位通常都是位元組。也就是說
乙個指標位址值可對應記憶體中乙個位元組的空間。3、
定址空間
:定址空間一般指的是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執行模式的定址位數決定
!
指標的大小到底是由誰決定?是多少?
應該說這是乙個非常基礎的問題,教科書上說指標大小和機器字長相同,即 32位機指標長度為 4位元組!但是對不對呢?為什麼是這樣?搜了一下相關資料。居然發現回答不統一,很多人也同樣是糊里糊塗。字長 在同一時間中處理二進位制數的位數叫字長。通常稱處理字長為 8位資料的 cpu叫8位 cpu,32位 cpu...
指標的大小到底是由誰決定?是多少?
32位處理器上32位作業系統的16位編譯器,指標大小2位元組。32位處理器上16位作業系統的16位編譯器,指標大小2位元組。16位處理器上16位作業系統的16位編譯器,指標大小2位元組。這從結果看起來指標的大小和編譯器有關?實際不是這樣的,有這樣的結果是因為以上幾種情況,處理器當前執行模式的定址位數...
指標的大小到底是由誰決定?是多少?
自 應該說這是乙個非常基礎的問題,教科書上說指標大小和機器字長相同,即32位機指標長度為4位元組!但是對不對呢?為什麼是這樣?搜了一下相關資料。居然發現回答不統一,很多人也同樣是糊里糊塗。下面對這個問題做乙個系統的整理和分析 字長 在同一時間中處理二進位制數的位數叫字長。通常稱處理字長為8位資料的c...