c++中的字節(jié)序與符號(hào)位的問(wèn)題
c++的字節(jié)序與符號(hào)位
看這樣一道題:
#include <stdio.h>
int main(void)?
{
?? ?int w, h;
?? ?int i = 0xa1b2c3d4;
?? ?char *p = (char *)&i;
?? ?for (int j = 0; j < 4; j++)
?? ?{
?? ??? ?char c = p[j];
?? ??? ?printf("%02x\n", c);
?? ?}
?? ?return 0;
}輸出結(jié)果是什么?
ffffffd4
ffffffc3
ffffffb2
ffffffa1
char只有一個(gè)字節(jié),打印出來(lái)卻是4個(gè)字節(jié),與想象的不一樣啊,
如果改動(dòng)一下就對(duì)了,
#include <stdio.h>
int main(void)?
{
?? ?int w, h;
?? ?int i = 0xa1b2c3d4;
?? ?unsigned char *p = (unsigned char *)&i;
?? ?for (int j = 0; j < 4; j++)
?? ?{
?? ??? ?unsigned char c = p[j];
?? ??? ?printf("%02x\n", c);
?? ?}
?? ?return 0;
}d4
c3
b2
a1
這是因?yàn)椋?/p>
1)在x86平臺(tái)是littelEndian字節(jié)序,所以會(huì)倒序,先遍歷到低位;
2)char 類型等于是有符號(hào),在打印時(shí)候,會(huì)將高位按照符號(hào)位補(bǔ)全1,所以會(huì)打印多余的FF,這里與printf的實(shí)現(xiàn)有關(guān)
c++多字節(jié)值與字節(jié)序
多字節(jié)值與字節(jié)序
大于8位(一字節(jié))的值稱為多字節(jié)量,在內(nèi)存中存儲(chǔ)多字節(jié)量有兩種方式:
小端:處理器儲(chǔ)存多字節(jié)值的最低有效字節(jié)于較低的內(nèi)存位置,則該微處理器就是小端處理器;
大端:微處理器儲(chǔ)存多字節(jié)值的最高有效字節(jié)于較低的內(nèi)存位置,則該處理器為大端處理器。

對(duì)于跨平臺(tái)應(yīng)用,字節(jié)序的兩種處理方式
- 所有數(shù)據(jù)以文字的方式寫入文件;多字節(jié)數(shù)值以一串十進(jìn)制數(shù)字,每個(gè)數(shù)字一個(gè)的寫入,這會(huì)浪費(fèi)磁盤空間。
- 工具先轉(zhuǎn)換字節(jié)序,然后再把轉(zhuǎn)換后的數(shù)據(jù)寫進(jìn)二進(jìn)制文件。
字節(jié)序的判斷
/*
*返回1小端
*返回0是大端
*/
int check_sys()
{
int i = 1;
return ((char)&i);
}整數(shù)字節(jié)序的轉(zhuǎn)換
typedef unsigned short U16;
typedef unsigned int U32;
U16 swapU16(U16 value)
{
return ((value & 0xFF00) >> 8 ) | ( (value & 0x00FF) << 8 );
}
U32 swapU32(U32 value)
{
return ( (value & 0x000000FF) << 24 )
| ( (value & 0x0000FF00) << 8 )
| ( (value & 0x00FF0000) >> 8 )
| ( (value & 0xFF000000) >> 24 );
}浮點(diǎn)數(shù)的字節(jié)序轉(zhuǎn)換
雖然浮點(diǎn)數(shù)有詳細(xì)的內(nèi)部結(jié)構(gòu),其中某些位作為尾數(shù),有些位作為指數(shù),并還有一個(gè)符號(hào)位,雖然其結(jié)構(gòu)復(fù)雜,但仍然可以把浮點(diǎn)數(shù)當(dāng)作整數(shù)轉(zhuǎn)成字節(jié)序:
typedef unsigned short U16;
typedef unsigned int U32;
typedef float F32;
union U32F32
{
U32 m_asU32;
F32 m_asF32;
};
U32 swapU32(U32 value)
{
return ( (value & 0x000000FF) << 24 )
| ( (value & 0x0000FF00) << 8 )
| ( (value & 0x00FF0000) >> 8 )
| ( (value & 0xFF000000) >> 24 );
}
F32 swapF32(F32 value)
{
U32F32 u;
u.m_asF32 = value;
u.m_asU32 = swapU32(u.m_asU32);
return u.m_asF32;
}以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解C語(yǔ)言中scanf函數(shù)使用的一些注意點(diǎn)
這篇文章主要介紹了C語(yǔ)言中scanf函數(shù)使用的一些注意點(diǎn),scanf函數(shù)的使用是C語(yǔ)言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-04-04
C++數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)鄰接表
這篇文章主要為大家詳細(xì)介紹了C++數(shù)據(jù)結(jié)構(gòu)之實(shí)現(xiàn)鄰接表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
C++實(shí)現(xiàn)約瑟夫環(huán)的循環(huán)單鏈表
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)約瑟夫環(huán)的循環(huán)單鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
淺談內(nèi)聯(lián)函數(shù)與宏定義的區(qū)別詳解
本篇文章是對(duì)內(nèi)聯(lián)函數(shù)與宏定義的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C語(yǔ)言實(shí)現(xiàn)三子棋游戲(初級(jí)版)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)三子棋游戲初級(jí)版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09

