欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

判斷機器大小端的兩種實現(xiàn)方法

 更新時間:2013年03月03日 14:50:40   作者:  
第一種方法,思路:利用指針的強制類型轉(zhuǎn)換。第二種方法,思路:利用共用體所有數(shù)據(jù)都從同一地址開始存儲。

第一種方法


思路:利用指針的強制類型轉(zhuǎn)換

復(fù)制代碼 代碼如下:

#include <stdio.h>
int main(void)
{   
int data1 = 0x12345678;  
int i;  
for(i=0; i<4; i++) 
{      
printf("%#x ----->%p\n",*((char *)&data1 + i),(char *)&data1 + i);  
}    
return 0;
}

從輸出的結(jié)果可以看出,高位地址0xbfc1b1ff存的是數(shù)據(jù)的高位0x12,低位地址0xbfc1b1fc存的是數(shù)據(jù)的低位0x78。所以是小端。同時我們亦可以看到,對數(shù)據(jù)data取地址實際指向的是存放低位數(shù)據(jù)的空間。

第二種方法

思路:利用共用體所有數(shù)據(jù)都從同一地址開始存儲。

復(fù)制代碼 代碼如下:

#include <stdio.h>

int main(void)

{

    int i;

    union endian

    {

        int data;

        char ch;

    }test;

    test.data = 0x12345678;

    if(test.ch == 0x78)

    {

        printf("little endian!\n");

    }

    else

    {

        printf("big endian!\n");

    }

 

    for(i=0; i<4; i++)

    {

        printf("%#x ------- %p\n",*((char *)&test.data + i),(char *)&test.data + i);

    }

    return 0;

}

相關(guān)文章

最新評論