最简单的方式教你理解大小端字节序

学过编程的人都应该知道大小端字节序的概念,但是很多时候,总是把他们弄混,这是整理出来的一份很简单的方式理解字节序的文章,废话不多说,这里直接入正题。

什么是字节序?

字节序,简单来说,就是指的超过一个字节的数据类型在内存中存储的顺序

那么就很明显了,像char这样的类型,肯定不存在字节序的问题了。


字节序分为哪几类?

大端字节序:

高位字节数据存放在低地址处,低位数据存放在高地址处;

小段字节序:

高位字节数据存放在高地址处,低位数据存放在低地址处;

网络字节序:

TCP/IP协议传输数据时,字节序默认大端

其实字节序只有大端字节序和小端字节序两种,网络字节序也是大端,这个以后会说到。关于大小端字节序的重点,上面已经标的很明显了,一个是高低地址,一个是高低位字节,那下面就看看这两个是什么意思?

重点来了

首先看什么是高地地址

在内存中,栈是向下生长的,以char arr[4]为例,(因为char类型数据只有一个字节,不存在字节序的问题)依次输出每个元素的地址,可以发现,arr[0]的地址最低,arr[3]的地址最高,如图:

接下来看什么是高低位

给一个十进制整数,123456,很明显左边的是高位,右边的是低位。计算机也是这样认为的。给一个16进制数,0x12345678,以字节为单位,从高位到低位依次是 0x12、0x34、0x56、0x78。

下来将高地地址和高低位对应。

一个整形占4个字节,给一个整形数据0x12345678,如果是大端存储,存储格式如下:

如果是小端存储,存储格式如下:

那如何判断当前系统是大端还是小端呢?

最简单地来说,我们可以用 1 为例,1在栈中存储的大小端格式分别如下图所示,

如果我们可以得到 1 在内存中存储的第一个字节,那么我们就可以知道当前系统是大端存储还是小端存储了。

测试代码如下:

#include <stdio.h>
int main()
{
	int a = 1;
	char pc = *(char*)(&a);
	if (pc == 1)
		printf("第一个字节为1,小端存储\n");
	else
		printf("第一个字节为0,大端存储\n");

	return 0;
}

/*********测试代码2***********/

#include <stdio.h>
union PORT
{
	int a;
	char c;
};
int main()
{
	union PORT p;
	p.a = 1;
	if (p.c == 1)
		printf("第一个字节为1,小端存储\n");
	else
		printf("第一个字节为0,大端存储\n");

	return 0;
}

-----muhuzz整理

时间: 2024-10-05 15:43:04

最简单的方式教你理解大小端字节序的相关文章

大小端字节序的来历(摘自《深入理解计算机系统 第三版》)

术语“little endian(小端)”和“big endian(大端)”出自Jonathan Swift的<格列佛游记>(Gulliver's Trabels)一书,其中交战的两个派别无法就应该从哪一端(小端还是大端)打开一个半熟的鸡蛋打成一致.就像鸡蛋的问题一样,选择何种字节顺序没有技术上的理由,因此争论沦为关于社会政治论题的争论. 一下是Jonathan Swift在1726年关于大小端之争历史的描述: “......下面要告诉你的是,Lilliput和Blefuscu这两大强国在过去

[C&amp;C++]大小端字节序转换程序

大端模式:  数据的高字节存在低地址  数据的低字节存在高地址 小端模式:  数据的高字节存在高地址  数据的低字节存在低地址 如图,i为int类型占4个字节,但只有1个字节的值为1,另外3个字节值为0:取出低地址上的值,当其为1时则为小端模式,为0时为大端模式. //大小端模式的判断 //方法一:利用联合体所有成员的起始位置一致, //对联合体中的int类型赋值,然后判断联合体中char类型的值的大小 #include <iostream> #include <iomanip>

大小端字节序

body { font-family: 微软雅黑,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif; font-size: 10.5pt; line-height: 1.5; } html, body { } h1 { font-size:1.5em; font-weight:bold; } h2 { font-size:1.4em; font-weight:bold; } h3 { fon

理解字节序 大端字节序和小端字节序

1. 计算机硬件有两种储存数据的方式:大端字节序(big endian)和小端字节序(little endian). 举例来说,数值0x2211使用两个字节储存:高位字节是0x22,低位字节是0x11. 大端字节序:高位字节在前,低位字节在后,这是人类读写数值的方法. 小端字节序:低位字节在前,高位字节在后,即以0x1122形式储存. 同理,0x1234567的大端字节序和小端字节序的写法如下图. 2. 我一直不理解,为什么要有字节序,每次读写都要区分,多麻烦!统一使用大端字节序,不是更方便吗?

大小端字节顺序

字节序的问题涉及硬件架构,目前主要是Motorola的PowerPC系列CPU和Intel的x86系列CPU.PowerPC系列采用big endian方式存储数据,而x86系列则采用little endian方式存储数据.那么究竟什么是big endian,什么又是little endian呢? 为方便理解,摘了INTER手册中的一张图.呵呵. 字节顺序是指占内存多于一个字节类型的数据在内存中的存放顺序,通常有小端.大端两种字节顺序.小端字节序指低字节数据存放在内存低地址处,高字节数据存放在内

大小端字节

1.概念 所谓大端小端,指的是对于多字节的数据类型(比如,int)在内存中存放的字节顺序.小端是指低地址的字节存放的是数据的低位,高地址字节存放的是数据的高位.大端是指低地址字节存放的是数据的高位,高地址字节存放数据的高位.简单地说,低位字节存放数据的高位就是大端,低位就是小端. 下面是一个例子,用来说明整数0x12345678在大端小端模式下不同的存放顺序. 内存地址 小端模式 大端模式 0x5250 0x78 0x12 0x5251 0x56 0x34 0x5252 0x34 0x56 0x

C语言 大小端 字节对齐

参考:http://www.cnblogs.com/graphics/archive/2011/04/22/2010662.html 1. 大端序:数据的高位字节存放在地址的低端,低位字节存放在地址的高端 2. 小端序:数据的高位字节存放在地址的高端,低位字节存放在地址的低端 记忆方式: 大端序是按照数字的书写顺序进行存储的,小端序是颠倒书写顺序进行存储的. 结构体对齐问题:http://www.cnblogs.com/clover-toeic/p/3853132.html

(转)大小端模式详解

int i=1; char *p=(char *)&i; if(*p==1) printf("1"); else printf("2"); 大小端存储问题,如果小端方式中(i占至少两个字节的长度)则i所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在i的最高地址字节处存放,char是一个字节,所以强制将char型量p指向i则p指向的一定是i的最低地址,那么就可以判断p中的值是不是1来确定是不是小端. 请写一个C函数,若处理器是Big_end

大小端的独特判定方法

看见这个判定方法很特别,收集了~ int i=1; char *p=(char *)&i; if(*p==1) printf("1"); else printf("2"); 大小端存储问题,如果小端方式中(i占至少两个字节的长度)则i所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在i的最高地址字节处存放,char是一个字节,所以强制将char型量p指向i则p指向的一定是i的最低地址,那么就可以判断p中的值是不是1来确定是不是小端. 请写一