[C/C++]_[初级]_[判断大小端序Little Endian Order]
场景:
1. 在读取硬盘数据和媒体数据时,需要根据读取的数据进行大小端序的转换,以正确识别数据。其中一个处理就是首先要判断cpu支持的大小端序情况才能转换.
2. Little Endian Order: 低地址存低位(整数的高低位)的数据.
test.cpp
#include <stdio.h> #include <iostream> using namespace std; //1.方法1,通过判断int的低位是否存储了数值. int IsLittleEndian1() { int x = 1; if (*(char*) &x == 1) { return 1; } else { return 0; } } //1.方法2,使用union的特性判断低位的int值 int IsLittleEndian2() { union w { int a; char b; }w1; w1.a = 1; return (w1.b == 1); } int main(int argc, char const *argv[]) { cout << "IsLittleEndian1:.................." << endl; if(IsLittleEndian1()) { cout << "Little Endian Order" << endl; }else { cout << "Big Endian Order" << endl; } cout << "IsLittleEndian2:.................." << endl; if(IsLittleEndian2()) { cout << "Little Endian Order" << endl; }else { cout << "Big Endian Order" << endl; } return 0; }
输出:
IsLittleEndian1:.................. Little Endian Order IsLittleEndian2:.................. Little Endian Order
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。