-1

这对我不起作用:

char buff[11];
char* msg_ptr;
msg_ptr = buff;
uint8_t id; 
uint32_t msg_length;
char msg[] = "hallo";
id = 77;
msg_length = 5;

memcpy(buff, &id, sizeof(uint8_t));
memcpy(buff+1, &msg_length, sizeof(uint32_t));
strcpy(buff+5, msg);


printf("id :%d\n",*(uint8_t*)msg_ptr);
msg_ptr++;

printf("msg_length: %d\n", *msg_ptr);

msg_ptr++;
printf("msg: %s\n", msg_ptr);

Id 和 msg_lentgh 显示在 konsole 上,但之后出现分段错误。我是C新手,请尽可能详细。问候

4

1 回答 1

0
msg_ptr = msg+1

那是你的问题。您应该执行 *msg_ptr++* 以转到下一个位置(即 *msg_len*)。相反,您将指针更改为指向msg字符串中的“a”。

代码中还有 2 个错误:

  • 您没有考虑字符串的终止 '\0'。你有 1 + 4 + 5 + 1,最后一个是终止的 '\0'。此外,在处理字符串时使用strncpy,它处理复制字符串终止符。memcpy将完全按照您的要求进行复制。你正在破坏你的堆栈。

  • 在最后一行,您必须将字符串打印为数字。使用 %s。

这是Wikipedia对 C 字符串和堆栈溢出的看法。

于 2012-05-17T15:36:08.573 回答