gpt4 book ai didi

c++ - memcpy 是否取决于源指针和目标指针的类型?

转载 作者:行者123 更新时间:2023-11-27 23:36:39 25 4
gpt4 key购买 nike

这段代码,

uint32_t length;
BYTE* message;
printf("Inspecting message with length %d and contents: ", length);
for(int i=0;i<length;i++)
printf("%d ", message[i]);
printf("\n");
....
char* outbuff;
outbuff = (char*) malloc(sizeof(char) * length + sizeof(int));
uint32_t data_length = htonl(length);
memcpy(outbuff, &data_length , sizeof(int));
memcpy(outbuff + sizeof(uint32_t), message, length);

printf("Sending outbuff over network with length %d and contents: ", length);
for(int i=0;i<length;i++)
printf("%d ", outbuff[i]);
printf("\n");

不会忠实地将消息和长度中的数据复制到 outbuff。但是一旦我将 outbuff 的类型从 char* 更改为 BYTE*,它就可以正常工作。

知道为什么它会这样吗? documentation在这件事上没有帮助。

EDIT.1:将 &length 更改为 &data_length。我手动输入代码而不是在 SX 中复制。

EDIT.2:打印出 BYTE 数组的代码。

最佳答案

我正在回答我自己编辑的新标题问题 ;-)。

答案很简单

您问题中的链接显示 memcpy() 声明为 void *memcpy(void *dest, const void *src, size_t n);。两个指针参数都是空指针。

标准草案将任何指向 void * 的指针的转换列为 标准转换(不需要显式转换)。 Specifically, it states (我强调):

A prvalue of type “pointer to cv T”, where T is an object type, can be converted to a prvalue of type “pointer to cv void”. The pointer value ([basic.compound]) is unchanged by this conversion.

这意味着您向它抛出的任何对象指针都将在 memcpy 看到它之前被转换为数值上相同的 void 指针,因此被相同地对待。

你的问题一定出在别处。

关于c++ - memcpy 是否取决于源指针和目标指针的类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58729851/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com