memcpy结构失败

时间:2012-05-09 07:25:45

标签: c memcpy

我试图将measure_msg(struct test)memcpy到缓冲区。但是,下面的代码似乎不会复制数据。值返回

**** ptr:0xb781c238
**** ptr:0xb781c23c
**** ptr:0xb781c244
buff[0]=5 - buff[1]=0 - buff[2]=0 - buff[3]=0 - buff[4]=W - buff[5]= - buff[6]= - buff[7]= - buff[8]= - buff[9]= - buff[10]= - buff[11]= - 

这段代码出了什么问题?

struct test{
  int mode;
  int id;
};

int func()
{   
int i, size;
struct test measure_msg;
char buff[20];
char* ptr;    

memset(&measure_msg, 0x00, sizeof(struct test));

ptr = buff;
fprintf(stderr, "**** ptr:%p\n", ptr);
sprintf(ptr, "%02d%02d", 50, 0);
ptr += 4;
size = 4;
size += sizeof(struct test);

fprintf(stderr, "**** ptr:%p\n", ptr);

measure_msg.id = 9999;
measure_msg.mode = 1111;

memcpy(ptr, &measure_msg, sizeof(struct test));
ptr += sizeof(struct test);

fprintf(stderr, "**** ptr:%p\n", ptr);

for (i=0; i<size; i++){
  fprintf(stderr, "buff[%d]=%c - ", i, buff[i]);
}

return 0;
}

3 个答案:

答案 0 :(得分:1)

你正在做一些奇怪的事情,但是看看这个:

sprintf(ptr, "%02d%02d", 50, 0);

您将在缓冲区中写入字符串。现在buf将包含“5000”。请注意,它不包含值50和0,但它们的字符串表示

现在,当您将缓冲区复制到结构时,您将其字段设置为这四个字节,但它们不是您在打印字符串时所看到的,而是 ASCII代码。请注意,在这一行:

fprintf(stderr, "buff[%d]=%c - ", i, buff[i]);

您将缓冲区的内容打印为字符,'5'存储为0x35(十进制53),然后它将是您结构的第一个字节的内容(依此类推)。

如果你真的想做什么你的代码是准确的(但你用指针玩的太多了,它只是一个测试吗?)但是真的很奇怪,否则你走错了方向去做你需要什么。

答案 1 :(得分:0)

memcpy()调用在我的系统上运行正常(GCC / MinGW,Windows)。你没有得到正确的输出,因为一些被复制到buff中的“字符”是不可打印的。

尝试

fprintf (stderr, "buff[%d]=%x - ", i, buff[i]);

代替。

数据将存储为

buff [0]  = 0x35  /* ASCII for '5' */
buff [1]  = 0x30  /* ASCII for '0' */
buff [2]  = 0x30
buff [3]  = 0x30
buff [4]  = 0x57  /* as 1111 is 0x00000457 in hex */
buff [5]  = 0x04  /* stored in little endian convention */
buff [6]  = 0x00  /* and here size of int = 4 */
buff [7]  = 0x00
buff [8]  = 0x0F  /* as 9999 is 0x0000270F in hex  */
buff [9]  = 0x27
buff [10] = 0x00
buff [11] = 0x00 

但是你还想通过将一个结构复制到一个字符数组来做什么呢?

答案 2 :(得分:0)

当您memcpy measure_msg buff时,您正在复制int类型值。之后,您将打印char类型值。 int类型值由4个字节组成,可能没有打印表示:即33752069 int值,0x02030405(十六进制格式),有4个字节,一旦像chars一样打印,你得到0x02,0x03,0x04和0x05 char值。

将您的打印masc更改为使用int值并将每个buff[i]强制转换为int,并打印您的值。

fprintf(stderr, "buff[%d]=%d - ", i, (int)buff[i])