龙空技术网

C|大端、小端字节序各自优势及判断

小智雅汇 1265

前言:

现在小伙伴们对“字节序大端小端”大约比较重视,各位老铁们都想要剖析一些“字节序大端小端”的相关内容。那么小编也在网络上搜集了一些关于“字节序大端小端””的相关知识,希望朋友们能喜欢,兄弟们快快来学习一下吧!

我们知道:

数据:高位→低位,如0x04030201,04是高位,01是低。

内存:低地址→高地址,如0x00000000→0xFFFFFFFF。

另外,计算机是按字长(如32位、64位)来访问内存数据的,而内存是按字节为单位来存储和编址的。

对于32位机,int = 0x04030201需要4个字节来存储,首字节(低地址)是存储04还是01呢?存储04(高位)的称为大端CPU,存储01(低位)的称为小端CPU。

小端字节序优势↓

大端字节序优势↓

因为字节序可能存在的问题↓

如何判断自己电脑是采用的大端还是小端?

#include <stdio.h>#include <stdlib.h>void Endian(){	int val = 0x04030201;	char firstByte = *(char*)&val;	printf("%x",&val);	if(firstByte==0x01)		printf("Little-Endian(小端):首地址存储数据的低位\n");	if(firstByte==0x04)		printf("Big-Endian(大端):首地址存储数据的高位\n");	char* p = &firstByte;}int main(){	Endian();	int val = 0x41424344;	FILE* fp;	if((fp=fopen("test.txt","wb"))==NULL)		return 0;	fwrite(&val,sizeof(val),1,fp);	fclose(fp);	system("type test.txt"); //DCBA(小端CPU)	if((fp=fopen("test.txt","rb"))==NULL)	{printf("ss");	return 0;}	unsigned char buf[1024];	if((fread(buf,sizeof(unsigned char),1024,fp))!=0)	{		int readVal = *(int*)&buf;		printf("\n%x\n",readVal); // 41424344	}	fclose(fp); system("pause");	return 0;}/*Little-Endian(小端):首地址存储数据的低位DCBA41424344*/

-End-

标签: #字节序大端小端