码迷,mamicode.com
首页 > 编程语言 > 详细

[C/C++]_[初级]_[判断大小端序Little Endian Order]

时间:2014-12-25 00:18:10      阅读:383      评论:0      收藏:0      [点我收藏+]

标签:c++   小端序   大端序   little endian order   big 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



[C/C++]_[初级]_[判断大小端序Little Endian Order]

标签:c++   小端序   大端序   little endian order   big endian order   

原文地址:http://blog.csdn.net/infoworld/article/details/42131387

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!