如何判斷CPU是大端還是小端模式

2021-06-16 19:11:10 字數 2017 閱讀 8834

如何判斷cpu是大端還是小端模式

2010-12-03 23:35:25

分類: c/c++

在arm體系中,每個字單元包含4個位元組單元或者兩個半字單元。在字單元中,4個位元組哪乙個是高位位元組,哪乙個是低位位元組則有兩種不同的格式:big-endian和little-endian格式。在小端模式中,低位位元組放在低位址,高位位元組放在高位址;在大端模式中,低位位元組放在高位址,高位位元組放在低位址。

在c語言中,不同於結構體,共用體(聯合體)中的幾種不同型別的變數存放在同一段記憶體單元中。利用這一特點,可以用聯合體變數判斷arm或x86環境下,儲存系統是是大端還是小端模式。

#include "stdio.h"

int main()

c;c.a=1;

if (c.b==1)

printf("it is little_endian!\n");

else

printf("it is big_endian!\n");

return 1;

}說明:

1  在c中,聯合體(共用體)的資料成員都是從低位址開始存放。

2  若是小端模式,由低位址到高位址c.a存放為0x01 00 00 00,c.b被賦值為0x01;

————————————————————————————

位址 0x00000000 0x00000001 0x00000002 0x00000003

測試cpu是大端big endian 還是小端little endian的c**

2023年11月29日

⁄ linux c/c++

⁄ 共 899字

⁄ 被圍觀 842 views+

看周立功的《c程式設計高階教程》做的筆記。這本書還不錯,已經幫我搞清楚了幾個以前比較迷糊的概念。

對於單一的位元組(a byte),大部分處理器以相同的順序處理位元(bit),因此單位元組的存放方法和傳輸方式一般相同。對於多位元組的資料,如int,long,有大端和小端之分。

最低有效位(least significant bit, lsb)表示數的最低位。

最高有效位(most significant bit, msb)表示數的最高位。對於帶符號數來說,最高位就是符號位。比如int 型別的「5」在32位機器上的表示為:0000 0000 0000 0000 0000 0000 0000 0101,其中,最左邊的一位0是符號位,即msb = 0; 最右邊的」1「是數的最低有效位,即lsb = 1。

注意:msb(全大寫)有時也指the most significant byte,最高有效位元組,指多位元組序列中具有最大權重的位元組。

如果將任何型別的物件指標強制轉換為指向任何char型別的指標,其結果就是」指向物件的第乙個位元組「的指標。無論系統的位元組次序結構如何,這裡所認定的第乙個位元組就是位址最低的那個位元組。**如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

#include

intmain()

else

return0;

}

如何判斷CPU是大端還是小端模式

在arm體系中,每個字單元包含4個位元組單元或者兩個半字單元。在字單元中,4個位元組哪乙個是高位位元組,哪乙個是低位位元組則有兩種不同的格式 big endian和little endian格式。在小端模式中,低位位元組放在低位址,高位位元組放在高位址 在大端模式中,低位位元組放在高位址,高位位元組...

如何判斷CPU是大端還是小端模式

arm體系中,每個字單元包含4個位元組單元或者兩個半字單元。在字單元中,4個位元組哪乙個是高位位元組,哪乙個是低位位元組則有兩種不同的格式 big endian和little endian格式。在小端模式中,低位位元組放在低位址,高位位元組放在高位址 在大端模式中,低位位元組放在高位址,高位位元組放...

判斷系統CPU是大端還是小端

所謂的大端小端就是cpu在儲存資料的時候是從高位址開始儲存還是低位址開始儲存。例如在sizeof int 2的系統中,1 2 8 1 512 513,我們把這個值賦值給int ntemp 1 2 8 我們假定系統分配給變數ntemp的位址空間為 0x0000ff08到0x0000ff09,那麼0x0...