码迷,mamicode.com
首页 > 其他好文 > 详细

memcpy与大小端

时间:2019-09-01 01:47:37      阅读:288      评论:0      收藏:0      [点我收藏+]

标签:memcpy   错误   class   net   合成   结果   https   传输数据   href   

搬运自我的CSDNhttps://blog.csdn.net/u013213111/article/details/100149145

参考:
大端 小端 与memcpy
网络字节序和大小端字节序

来看这样一段代码:
本意是想把uint8_t a[2]中的内容合成一个uint16_t b

#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>

int main()
{
    uint8_t a[2] = { 0x11, 0x22 };
    uint16_t b;
    memcpy(&b, a, sizeof(b));

    printf("a[0]:%x,a[1]:%x\n", a[0], a[1]);
    printf("b:%x\n", b);

    return 0;
}

在intel的电脑上跑出来的结果如何呢:

a[0]:11,a[1]:22
b:2211

也就是说,假如a[1]中存储的是高位byte,a[0]中存储的是低位byte,那么最终合成的uint16_t是正确的;而假如a[0]中存储的是高位byte,a[1]中存储的是低位byte,那么结果就是错误的了。
然而并不是所有的计算机系统都如此,而是要看系统是大端存储模式还是小端存储模式。
小端存储模式(小端字节序),指的是数据的高字节位置保存在内存的高地址处,数据的低字节保存在内存的低地址处,例如intel x86采用的就是小端存储模式。
相反地,大端存储模式(大端字节序),指定就是把数据的高字节保存在内存的低地址中,数据的低字节保存在内存的高地址中。

当计算机之间通过网络传输数据时,就特别需要注意大小端的问题。首先,不同的计算机系统可能并不都采用大端模式或者都采用小端模式,在混用存储模式的情况下,就有可能导致数据读取的错误;其次,由于网络字节序被规定为大端字节序,而如果计算机采用的是小端字节序,那么就需要进行一次转换了。

memcpy与大小端

标签:memcpy   错误   class   net   合成   结果   https   传输数据   href   

原文地址:https://www.cnblogs.com/lyrich/p/11441099.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!