繁体   English   中英

C memcpy与unsigned char数组有关

[英]C memcpy issues with unsigned char array

我有一个关于memcpy的问题,希望有人能回答。 这是一个简短的示范程序:

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


int main (int argc, char **argv){
  unsigned char buffer[10];
  unsigned short checksum = 0x1234;
  int i;
  memset(buffer, 0x00, 10);
  memcpy(buffer, (const unsigned char*)&checksum, 2);
  for(i = 0; i < 10; i ++){
    printf("%02x",buffer[i]);
  }
  printf("\n");
  return 0;
}

当我运行这个程序时,我得到34120000000000000000。
我的问题是为什么我得不到12340000000000000000?

非常感谢

您将获得34120000000000000000,因为您使用的是小端系统。 您将在big-endian系统上获得12340000000000000000。 Endianness对big-endian系统与little-endian系统进行了全面讨论。

小端/大端架构? 这意味着2字节的校验和被反转。

这只是一个猜测,如果我的答案不是真的那么评论它我将删除它。

英特尔的CPU是小端,它们首先存储的数字很少

这显然是英特尔不进行内部药物测试的证据。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM