新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 在ARM系統(tǒng)應(yīng)用的數(shù)據(jù)類型

在ARM系統(tǒng)應(yīng)用的數(shù)據(jù)類型

作者: 時間:2016-11-11 來源:網(wǎng)絡(luò) 收藏
數(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)把一個整數(shù)截?cái)喑晌粩?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ù)據(jù)來表示。
3.指針類型的數(shù)據(jù)
下面的規(guī)則適用于處數(shù)據(jù)成員指針以外的其他指針:
**NULL被定義為0。
**相鄰的兩個存儲單元地址相差一。
**在指向函數(shù)的指針和指向數(shù)據(jù)的指針進(jìn)行數(shù)據(jù)轉(zhuǎn)換時,編譯器將會產(chǎn)生警告信息。
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指針類型的數(shù)據(jù)相減時,結(jié)果可以按照下面的公式得到。
((int)a-(int)b)/(int)sizeof(type pointed to)
這時,只要指針?biāo)傅膶ο蟛皇莗ack的,其對齊特性能夠滿足整除的要求。


評論


技術(shù)專區(qū)

關(guān)閉