所以我有以下内容:
int from[2][3] = { {1,2,3}, {2,3,4} };
int into[3];
into = memcpy(into, from[0], 3 * sizeof(*into));
我想复制'from' in到数组'into'这样'into' = {1,2,3}
我正在尝试使用memcpy(我知道它已经与循环一起工作),但我似乎无法让它工作。
我一直得到错误:
error: incompatible types when assigning to type ‘int[3]’ from type ‘void *’
我找到了这个问题的链接:
如何将一维数组复制到另一个二维数组的一部分,反之亦然?
并更改了我的代码(上面),但我仍然得到错误。
我仍然无能为力,我已经用另一种方式解决了我的问题,但好奇的是,我想知道它是如何做到的,因为从以前的帖子我知道这是可能的。
正如KingsIndian指出的那样,可以通过放弃赋值来避免这个问题,因为在这个实例中实际上并不需要返回值。然而,它可能有助于未来了解幕后发生了什么:
memcpy返回指向目的地的指针。如果"into"是一个指针,那就没问题了:
int from[2][3] = { {1,2,3}, {2,3,4} };
int into[3];
int *into_ptr = into;
into_ptr = memcpy(into_ptr, from[0], 3 * sizeof(int)); // OK
问题在于"into"是一个数组,而不是指针。C语言中的数组不是变量,也就是说,它们不能被赋值,因此会出现错误。虽然人们常说数组和指针是等价的,但它们是有区别的,这就是其中之一。关于数组和指针之间的区别的更多细节在这里给出:
http://eli.thegreenplace.net/2009/10/21/are-pointers-and-arrays-equivalent-in-c/编辑:为了避免这个问题而不做任何赋值,忽略返回值:
int from[2][3] = { {1,2,3}, {2,3,4} };
int into[3];
memcpy(&into[0], from[0], sizeof(into));
memcpy返回一个指向目标的指针,您试图将该指针赋值给数组。可以忽略memcpy的返回值。
#include <string.h>
void *memcpy(void *dest, const void *src, size_t n);
你可能想要的是:
memcpy(into, from[0], sizeof into);
这将从from[0]
复制每个4字节的3个元素(这里是sizeof into == 12
)到into
。