ARM編譯器支持的數據類型
***************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位保存在低地址的字ARM編譯器數據宏單元中,高32為保存在高地址的字單元中;在big
endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數據的操作遵守下面的規則:
**所有帶符號的整型書的運算是按照二進制的補碼ARM編譯器數據宏進行的。
**帶符號的整型數的運算不進行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**制定的移位位數的數是8位的無符號數。
**進行移位操作的數被作為32位數。
**超過31位的邏輯左移的結果為0。
**對于無符號數和有符號的正數來說,超過32位的右移操作結果為0;對于有符號的負數ARM編譯器數據宏來說,超過32位的右移操作結果為-1。
**整數除法運算的余數和除數有相同ARM編譯器數據宏的符號。
**當把一個整數截斷成位數更短的整數類型的數時,并不能保證所ARM編譯器數據宏得到的結果的zui高位的符號位的正確性。
**整型數據之間的類型轉換不會產生異常中斷。
**整型數據的溢出不會產生異常中斷。
**整型數據除以0將會產生異常中斷。
2.浮點數
在ARM體系中,浮點數是按照IEEE標準存儲的。
**float類型的數是按照IEEE的單精度ARM編譯器數據宏數表示的。
**double和long double 是用IEEE的雙精度數表示的。
對于浮點數的操作遵守下面的規則:
**遵守正常的IEEE754規則。
**當默認情況下禁止浮點數運算ARM編譯器數據宏異常中斷。
**當發生卷繞時,用zui接近的數據來表示。
3.指針類型的數據
下面的規則適用于處數據成員指針以外的其他ARM編譯器數據宏指針:
**NULL被定義為0。
**相鄰的兩個存儲單元地址相差一。
ARM編譯器數據宏
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指針類型的數據相減時,結果可以按照下面的公式ARM編譯器數據宏得到。
((int)a-(int)b)/(int)sizeof(type pointed to)
這時,只要指針所指ARM編譯器數據宏的對象不是pack的,其對齊特性能夠滿足整除的要求。
***************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位保存在低地址的字ARM編譯器數據宏單元中,高32為保存在高地址的字單元中;在big
endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數據的操作遵守下面的規則:
**所有帶符號的整型書的運算是按照二進制的補碼ARM編譯器數據宏進行的。
**帶符號的整型數的運算不進行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**制定的移位位數的數是8位的無符號數。
**進行移位操作的數被作為32位數。
**超過31位的邏輯左移的結果為0。
**對于無符號數和有符號的正數來說,超過32位的右移操作結果為0;對于有符號的負數ARM編譯器數據宏來說,超過32位的右移操作結果為-1。
**整數除法運算的余數和除數有相同ARM編譯器數據宏的符號。
**當把一個整數截斷成位數更短的整數類型的數時,并不能保證所ARM編譯器數據宏得到的結果的zui高位的符號位的正確性。
**整型數據之間的類型轉換不會產生異常中斷。
**整型數據的溢出不會產生異常中斷。
**整型數據除以0將會產生異常中斷。
2.浮點數
在ARM體系中,浮點數是按照IEEE標準存儲的。
**float類型的數是按照IEEE的單精度ARM編譯器數據宏數表示的。
**double和long double 是用IEEE的雙精度數表示的。
對于浮點數的操作遵守下面的規則:
**遵守正常的IEEE754規則。
**當默認情況下禁止浮點數運算ARM編譯器數據宏異常中斷。
**當發生卷繞時,用zui接近的數據來表示。
3.指針類型的數據
下面的規則適用于處數據成員指針以外的其他ARM編譯器數據宏指針:
**NULL被定義為0。
**相鄰的兩個存儲單元地址相差一。
ARM編譯器數據宏
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指針類型的數據相減時,結果可以按照下面的公式ARM編譯器數據宏得到。
((int)a-(int)b)/(int)sizeof(type pointed to)
這時,只要指針所指ARM編譯器數據宏的對象不是pack的,其對齊特性能夠滿足整除的要求。
上一篇:ARM基礎知識學習八
下一篇:ARM基礎知識學習五
全年征稿/資訊合作
聯系郵箱:1271141964@qq.com
免責聲明
- 凡本網注明"來源:智能制造網"的所有作品,版權均屬于智能制造網,轉載請必須注明智能制造網,http://www.xashilian.com。違反者本網將追究相關法律責任。
- 企業發布的公司新聞、技術文章、資料下載等內容,如涉及侵權、違規遭投訴的,一律由發布企業自行承擔責任,本網有權刪除內容并追溯責任。
- 本網轉載并注明自其它來源的作品,目的在于傳遞更多信息,并不代表本網贊同其觀點或證實其內容的真實性,不承擔此類作品侵權行為的直接責任及連帶責任。其他媒體、網站或個人從本網轉載時,必須保留本網注明的作品來源,并自負版權等法律責任。
- 如涉及作品內容、版權等問題,請在作品發表之日起一周內與本網聯系,否則視為放棄相關權利。
2025長三角國際智能儀表/線纜產業博覽會
展會城市:滁州市展會時間:2025-11-11