我试图将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;
}
答案 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])