Heim  >  Artikel  >  Backend-Entwicklung  >  C/C++中字节序、类型转化的深入理解

C/C++中字节序、类型转化的深入理解

高洛峰
高洛峰Original
2016-11-17 13:12:362115Durchsuche

 如果将字节序、类型转化单独一个拿出来说时,大家可能都觉得很简单,但是理解的不深入。如果将其结合起来探讨,可能我们就会理解的很透彻。

关于字节序和类型转化的基础,大家如果不太理解,可以参考以下博客:

https://my.oschina.net/u/1783725/blog/647973  大小字节序

https://my.oschina.net/u/1783725/blog/700970  类型转化

在进入正题之前,在啰嗦一句:

系统位数不同对应数据类型的字节数大小也不同

QQ图片20161117130906.png

详细介绍两者之间的联系

字节序: 操作的内存,就是将我们看到的数据存放在内存中的规则。

    大字节序:大端有效 ,高位数据先放入低地址内存 , 低位数据放入高地址内存;小字节序:小端有效,低位数据先放入低地址内存 , 高位数据再放入高地址内存

    操作内存(如:memcpy)就需要考虑字节序

QQ图片20161117104700.png

类型转化: 操作的是读出的数据,就是将从内存中读取的数据,根据类型字节的大小进行转化。

位数多的转化为位数小的(会截断高位的数据,留下地位的数据),位数小的转化为位数多的(将高位的数据补为0)。  

QQ图片20161117104700.png

一个例子来读懂他们

1、赋值与字节序无关,操作内存(memcpy)就需要考虑字节序

1:将unsigned  long  long类型的0xABCDEF1234赋值给unsigned  long类型的变量,与字节序无关

2:unsigned  long  long类型的0xABCDEF1234变量使用memcpy到short类型的变量,发现为0,与字节序有关

代码如下:

#include <stdio.h>int main(int argc, char *argv[])
{
	unsigned long long ullVar = 0xABCD1234;	
	unsigned long ulVar1 = 0;	
	unsigned long ulVar2 = 0;	
	/*memcpy操作内存时,需要考虑系统的大小字节序,如果是大字节序的话,高位的数据保存在低地址上*/
	memcpy(&ulVar1,&ullVar,sizeof(ulVar1));	/*赋值时,就是讲读出的数据按照要赋值的数据类型的大小进行转换*/
	ulVar2 = ullVar;	printf("ulVar1=%x      ulVar2=%x \n",ulVar1,ulVar2); 
	//输出:ulVar1=0      ulVar2=abcd1234
	return 0;
}


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn