3

我有一大块内存,我将这些内存的一部分传递给这些函数:

void setBlockSize(char* node, int size) {
    printf("need size: %i\n",size);
    memcpy(node, (void *)&size, sizeof(size));
    printf("set to: %i\n",node); 
}

//written for 4 byte pointer, 32 bit addressing
void setNextPointer(char* node, char* next){
    printf("need ptr: %p\n", next);
    memcpy((node+4), (void*)&next, sizeof(next));
    printf("next: %p, set: %p\n",next, (void*)(node+4));
}

我的输出如下:

need size: 8296
set to: 137666560
need ptr: (nil)
next: (nil), set: 0x834a004
need size: 137666456
set to: 137666560
need ptr: 0xffee4874
next: 0xffee4874, set: 0x834a004
need size: 104
zsh: segmentation fault (core dumped)  ./mallocTest

似乎设置了错误的值(我正在尝试设置一个指针和一个整数。这对 memcpy 的用法不正确吗?

4

1 回答 1

3

在第一个函数中,当您输出刚刚写入的值时,您并没有取消引用指针。试试这个:

printf("set to: %i\n", *(int*)node); 

第二个函数也存在同样的问题。您想输出存储在指针中的指针值node+4,而不是node+4本身:

printf("next: %p, set: %p\n", next, *(void*)(node+4));

只是关于memcpy,用它来写一个值是很奇怪的。你可以避免memcpy这样:

*(int*)node = size;
*(char**)(node+4) = next;
于 2013-11-07T03:53:45.130 回答