|
************************************************************* ARM編譯器支持的數(shù)據(jù)類型 ************************************************************ 數(shù)據(jù)類型 長度(位) 對齊特性 Char 8 1(字節(jié)對齊) 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.整數(shù)類型 在ARM體系中,整數(shù)類型是以2的補(bǔ)碼形式存儲的。對于long long類型來說,在little endian內(nèi)存模式下,其低32位保存在低地址的字單元中,高32為保存在高地址的字單元中;在big endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數(shù)據(jù)的操作遵守下面的規(guī)則: **所有帶符號的整型書的運(yùn)算是按照二進(jìn)制的補(bǔ)碼進(jìn)行的。 **帶符號的整型數(shù)的運(yùn)算不進(jìn)行符號的擴(kuò)展。 **帶符號的整型數(shù)的右移操作是算數(shù)移位。 **制定的移位位數(shù)的數(shù)是8位的無符號數(shù)。 **進(jìn)行移位操作的數(shù)被作為32位數(shù)。 **超過31位的邏輯左移的結(jié)果為0。 **對于無符號數(shù)和有符號的正數(shù)來說,超過32位的右移操作結(jié)果為0;對于有符號的負(fù)數(shù)來說,超過32位的右移操作結(jié)果為-1。 **整數(shù)除法運(yùn)算的余數(shù)和除數(shù)有相同的符號。 **當(dāng)把一個(gè)整數(shù)截?cái)喑晌粩?shù)更短的整數(shù)類型的數(shù)時(shí),并不能保證所得到的結(jié)果的最高位的符號位的正確性。 **整型數(shù)據(jù)之間的類型轉(zhuǎn)換不會產(chǎn)生異常中斷。 **整型數(shù)據(jù)的溢出不會產(chǎn)生異常中斷。 **整型數(shù)據(jù)除以0將會產(chǎn)生異常中斷。 2.浮點(diǎn)數(shù) 在ARM體系中,浮點(diǎn)數(shù)是按照IEEE標(biāo)準(zhǔn)存儲的。 **float類型的數(shù)是按照IEEE的單精度數(shù)表示的。 **double和long double 是用IEEE的雙精度數(shù)表示的。 對于浮點(diǎn)數(shù)的操作遵守下面的規(guī)則: **遵守正常的IEEE754規(guī)則。 **當(dāng)默認(rèn)情況下禁止浮點(diǎn)數(shù)運(yùn)算異常中斷。 **當(dāng)發(fā)生卷繞時(shí),用最接近的數(shù)據(jù)來表示。 3.指針類型的數(shù)據(jù) 下面的規(guī)則適用于處數(shù)據(jù)成員指針以外的其他指針: **NULL被定義為0。 **相鄰的兩個(gè)存儲單元地址相差一。 **在指向函數(shù)的指針和指向數(shù)據(jù)的指針進(jìn)行數(shù)據(jù)轉(zhuǎn)換時(shí),編譯器將會產(chǎn)生警告信息。 **類型size_t被定義為unsigned int. **類型ptrdiff_t被定義為signed int。 **兩個(gè)指針類型的數(shù)據(jù)相減時(shí),結(jié)果可以按照下面的公式得到。 ((int)a-(int)b)/(int)sizeof(type pointed to) 這時(shí),只要指針?biāo)傅膶ο蟛皇莗ack的,其對齊特性能夠滿足整除的要求。 |