*************************************************************
ARM編譯器支援的數據類型
************************************************************

數據類型 長度(位) 對齊特性
Char 8 1(位元組對齊)
short 16 2(百字對齊)
Int 32 4(字對齊)
Long 32 4(字對齊)
Longlong 64 4(字對齊)
Float 32 4(字對齊)
Double 64 4(字對齊)
Long double 64 4(字對齊)
All pointers 32 4(字對齊)
Bool(C++ only) 32 4(字對齊)

  1.整數類型

  在ARM體系中,整數類型是以2的補碼形式存儲的。對於long long類型來說,在little endian內存模式下,其低32位儲存在低位址的字單元中,高32為儲存在高位址的字單元中;在big endian模式下,其低32位儲存在高位址的字單元中,高32為儲存在低位址的字單元中。對於整型數據的操作遵守下面的規則︰

**所有帶符號的整型書的運算是按照二進製的補碼進行的。
**帶符號的整型數的運算不進行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**製定的移位位數的數是8位的無符號數。
**進行移位操作的數被作為32位數。
**超過31位的邏輯左移的結果為0。
**對於無符號數和有符號的正數來說,超過32位的右移操作結果為0;對於有符號的負數來說,超過32位的右移操作結果為-1。
**整數除法運算的餘數和除數有相同的符號。
**當把一個整數截斷成位數更短的整數類型的數時,並不能保證所得到的結果的最高位的符號位的正確性。
**整型數據之間的類型轉換不會產生異常中斷。
**整型數據的溢出不會產生異常中斷。
**整型數據除以0將會產生異常中斷。

  2.浮點數

  在ARM體系中,浮點數是按照IEEE標準存儲的。

**float類型的數是按照IEEE的單精度數表示的。
**double和long double 是用IEEE的雙精度數表示的。

  對於浮點數的操作遵守下面的規則︰

**遵守正常的IEEE754規則。
**當預設情況下禁止浮點數運算異常中斷。
**當發生捲繞時,用最接近的數據來表示。

  3.指標類型的數據

  下面的規則適用於處數據成員指標以外的其他指標︰

**NULL被定義為0。
**相鄰的兩個存儲單元位址相差一。
**在指向函數的指標和指向數據的指標進行數據轉換時,編譯器將會產生警告訊息。
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指標類型的數據相減時,結果可以按照下面的公式得到。
((int)a-(int)b)/(int)sizeof(type pointed to)

  這時,只要指標所指的對象不是pack的,其對齊特性能夠滿足整除的要求。

立你斯 發表在 痞客邦 留言(0) 人氣()