将DWORD写入内存只覆盖1个字节,而不是4个字节
Writing DWORD to memory overwrites only 1 byte instead of 4
我有
typedef unsigned int DWORD;
void write_str(string str, char** buf) {
DWORD len = str.size();
**buf = len;
*buf += sizeof(len);
memcpy(*buf, str.c_str(), len);
*buf += len;
}
这段代码,如果我在len中有7,则只有1个字节被覆盖在**buf = len;
中,而4应该是,因为(DWORD)的大小=4
由于buf
是char **
,**buf
是char
。它只能容纳一个字节。因此,只向其中写入一个字节。
修复:
DWORD *tmpptr(*buf);
*tmpptr = len;
C++自动将len转换为char,因为*buf
就是这样。
您有参数
char** buf
这意味着**buf
是一个字符,很可能是一个单字节。
1个字节被覆盖,因为目标类型是char(**buf
的类型是char)。这是正确的。但在我看来,*buf += sizeof(len)
这个词没有任何意义。
相关文章:
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 如何使用 OpenCV 解码在两个 UWP 应用之间发送的图像字节?
- 找到一种有效的方法,在 2 个巨大的缓冲区上执行 MAX,每字节字节
- 为什么 bool 和 _Bool 如果它们在内存中占用 1 个字节,它们只能存储 0 或 1
- 在 Linux 中,uint32_t从 4 个字节更改为 6 个字节
- 运行时错误:引用绑定到类型"int"的未对齐地址0xbebebebebebebec6,这需要 4 个字节对齐 (stl_vector.h)
- 向指针地址添加 20 个字节偏移量
- 将(N 个字节)无符号字符指针转换为浮点数和双 C++
- C++/地址空间:每个地址 2 个字节?
- 为什么这个结构需要 24 个字节
- 为什么带有 vptr 的对象长 12 个字节?
- 使用 valgrind 检查我的链表暗示中的内存泄漏,让我"肯定丢失:1 个块中有 40 个字节"
- 复制后删除原始数组指针将前 3 个字节设置为 0
- 在编译时而不是运行时创建一个由两个字节组成的值
- 为什么在我的实现中,所有数组都对齐到 16 个字节?
- 使用 Python 导出 4 个字节浮点数
- C++向指针地址添加 4 个字节
- 是否强制转换void**并将第一个字节设置为nullptr
- AES-128 CFB-8解密的前16个字节已损坏
- 检查 IP 第一个八位字节是否不以 127 / 224 或 255 开头