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

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

 

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

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,与字节序有关

代码如下:

1

2

3

4

5

6

7

8

9

10

11

#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;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值