首页 > 代码库 > 字节序之大端小端
字节序之大端小端
时间:2014.07.18
地点:基地
-----------------------------------------------------------------------------
一、跨多字节对象
对应跨多字节的程序对象,有两个点:一是这个对象的地址是什么。二是在内存中,这多个字节是如何存储的。我们知道,多字节对象都是被存储为连续的字节序列,对象的地址即使用字节中最小的那个地址。比如一个int型数据变量x,我们说它的存储地址为0x100,即&x的值为0x100,x是一个4字节对象,那么它的4个字节将从0x100地址处开始一次存储在0x100,0x101,0x102,0x103等位置。
-----------------------------------------------------------------------------
二、字节序
考虑一个w位整数,我们将w位8个位一组进行划分(假设w为8的整数倍,不足可补齐)形成一个个的字节,那么最左边一个字节称为最高有效字节,最右边一个字节称为最低有效字节。于是我们又导出两种存储模式:
1.某些机器的存储器按最低有效字节到最高有效字节的顺序存储对象——这叫小端法(大多数Intel兼容机采用)
2.某些机器的存储器按最高有效字节到最低有效字节的顺序存储对象——这叫大端法(IBM,SUM等采用)
例子:
假设int型变量x的十六进制值为 0x 01 23 45 67 ,地址为:0x100(即存储起始地址),下面给出大端小端两种存储方式。
地址: ......0x100 0x101 0x102 0x103......
大端: 01 23 45 67 (打最高有效字节开始存起)
小端: 67 45 23 01 (打最低有效字节开始存起)
-----------------------------------------------------------------------------
三、检查自身机器大端小端方式
#include<cstdio> typedef unsigned char* byte_ptr; void ShowBytes(byte_ptr start, int len) { for (int i = 0; i < len; ++i) printf("%.2x", start[i]); printf("\n"); } void ShowInt(int x) { ShowBytes((byte_ptr)&x, sizeof(int)); } void ShowFloat(float x) { ShowBytes((byte_ptr)&x, sizeof(float)); } void ShowPoint(void* x) { ShowBytes((byte_ptr)&x, sizeof(void*)); } int main() { int data = http://www.mamicode.com/12345;>