字节序之大端小端

时间: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 = 12345;
	ShowInt(data);
	return 0;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值