我完全不知道为什么memcpy或memmove对我不起作用。
我正在尝试将一个struct(joblist)数组复制到另一个具有相同结构(Q)的数组,以用于数据操作,同时保持原始数组的完整。
我花了很多时间在SO和谷歌上进行故障排除,我无法找到它为什么不能工作。
Q = new AdjacencyList[numjobs + 1]; //create a queue
// Q = joblist;
memmove(&Q, &joblist, sizeof(AdjacencyList) );
Q[0].jobnum = 30;
我试图让Q = joblist,但是当我在一个中更改一个值时,它在两者中都发生了变化。
struct AdjacencyList {
NodeType state; // what is present state of job?
NodePath path; // is job part of critical path?
int jobnum;
int edges;
int tocount;
int fromcount;
int to[50];
int from[50];
};
AdjacencyList *joblist;
AdjacencyList *Q;
这是我创建的结构。
*** Error in `p5.out': corrupted double-linked list: 0x0989e8c0 ***
======= Backtrace: =========
/lib/libc.so.6[0x47975143]
/lib/libc.so.6[0x4797b984]
/lib/libc.so.6[0x4797cd28]
/lib/libstdc++.so.6(_ZdlPv+0x20)[0x47d8d9e0]
/lib/libstdc++.so.6(_ZdaPv+0x1c)[0x47d8da3c]
非常感谢任何帮助。感谢。
SUB
答案 0 :(得分:2)
他们打电话给memmove(dst, src, sizes)
。是不正确的。它应该是
memmove(Q, joblist, sizeof(AdjacencyList) * (numjobs + 1));
更新:
就像它的名字一样,memmove
在内存上运行。它只是将sizes
字节数据从src
复制到dst
。
如果要将n个对象的数组复制到Q
,则必须告诉函数您要复制的数据的总大小,即size of each objects * number of objects
。我不知道你需要复制多少个对象,numjobs + 1
只是一个例子。如果您要复制numjobs
,则应为sizeof(AdjacencyList) * numjobs
。
答案 1 :(得分:1)
memmove(&Q, &joblist, sizeof(AdjacencyList) );
错误并导致未定义的行为。它会将sizeof(AdjacencyList)
字节从joblist
的地址复制到Q
的地址。
您需要使用的是:
memmove(Q, joblist, sizeof(AdjacencyList) );
将一个对象从joblist
复制到Q
。如果要复制numjobs + 1
个对象,则需要使用:
memmove(Q, joblist, sizeof(AdjacencyList)*(numjobs + 1));