【C语言】大小端的判断

在文章的开头我首先要介绍一下大小端的概念:

大端模式:
是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;
 
小端模式:
是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。
 
 
若将00000001放入计算机中就有两种方法:
 
 
—————————————————————>                    小端

低地址            01       00        00        00           高地址

 

 

—————————————————————>                   大端

高地址            00       00        00        01          低地址

 

但是我们应该怎样判断当前计算机的存储模式呢??

首先用指针法:

#include
int main()
{
	char c;
	int a=1;
	int *p=&a;
	c = *p;
	if(c==a)
	{
		printf("xiaoduan\n");
	}
	else
	{
		printf("daduan\n");
	}

return 0;	


}


在介绍第二种解法前,我们首先简单介绍一下联合体的概念:

计算机科学中,联合体英语:union)一种具有多个类型或格式的值,或者把它定义为一种由具有这样的值的变量形成的数据结构。一些编程语言可以支持被称为“联合体”的特殊的资料类型,来表示上述的变量。换句话说,一个联合体的定义(defenition)会指定一些允许的可以存储在实例内的原始数据类型(例如整型,浮点)。和记录(record)(或结构,structure)那些可以被定义去包含一个浮点数或整型不同的是,在一个联合体任何时候只有一个值。

 

联合体法:

#include
union UN
{
	int a;
	char c;
}un;
int main()
{
	union UN un;
	un.a=1;
	if(un.c=1)
	{
		printf("xiaoduan\n");
	}
	else
	{
		printf("daduan\n");
	}

return 0;	

	
}


两个的运行结果都是:

 

 

 

 

 

 

你可能感兴趣的:(【C语言】大小端的判断)