大端、小端问题

大端、小端问题

1.大小端概念

大端:将数据的地位,放到内存的高地址处;

小端:将数据的地位,放到内存的地地址处;

在计算机中,内存是存储容量以字节为基本单位的;

数据是用 二进制为基本单位的

2.数据在内存中的地址

我们拿一个整形举例,一个整形,在32位平台下占4个字节,但是取地址时,我们通常认为数值最小的那个地址是这个整形的地址。

3.如何验证

//方法一;
int check_sys()
{
	int i = 1;
	return (*(char*)&i);
}
int main()
{
	int ret = check_sys();
	if (ret == 1)
		printf("小端\n");
	
	else
		printf("大端\n");
	return 0;
}
  int i=1  //以32 位为例, 整形在内存中占4个字节,以补码形式储存

        0x1              0x2             0x3             0x4       ——>计算机中内存的增长 (模拟)

  0000 0001 0000 0000 0000 0000 0000 0000 ——>小端

  0000 0000 0000 0000 0000 0000 0000 0001 ——>大端

char类型占1个字节

  如果是小端,在(char*)强转时截取低地址处1个字节,解引用返回是1;

  反之是 0,则说明是大端;
//方法二
int check_sys()
{
	union X
{
	int i;
	char j;

}x;
    x.i=1;
    return x.j;
}
int main()
{
	int ret = check_sys();
	if (ret == 1)
		printf("小端\n");
	
	else
		printf("大端\n");
	return 0;
}
方法二在原理上与方法一样,在实现形式上有所不同;
联合体里面的成员变量共用一块空间;
返回 x.j时,截取低地址处;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值