c/c++ int,float,short 大小端轉換函數


unsigned int(uint32_t)大小端轉換函數

unsigned int BLEndianUint32(unsigned int value)
{
    return ((value & 0x000000FF) << 24) |  ((value & 0x0000FF00) << 8) |  ((value & 0x00FF0000) >> 8) | ((value & 0xFF000000) >> 24);   
}

float大小端轉換函數

由於Float類型的數據在計算中保存方法不一樣, 所以對Float類型的數據做大小端轉換的情況不能簡單的通過宏移位來完成。

typedef union FLOAT_CONV
{
    float f;
    char c[4];
}float_conv;


float BLEndianFloat(float value)
{
    float_conv d1,d2;
    d1.f = value;
    d2.c[0] = d1.c[3];
    d2.c[1] = d1.c[2];
    d2.c[2] = d1.c[1];
    d2.c[3] = d1.c[0];
    return d2.f;
}

unsigned short大小端轉換函數

unsigned short BLEndianUshort(unsigned short value)
{
    return ((value & 0x00FF) << 8 ) | ((value & 0xFF00) >> 8);
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM