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