您遇到的困难是因为您没有在您的Init
函数中创建3指针类型struct Ex
。您只是创建一个指向的内存块,该内存块足够容纳3个结构体Ex。这很好,但不能依赖正常的数组语法来传递或访问ex
中的值。 您负责在ex
内提供指向您想要的任何值的指针地址。
以下是您的代码的一个简单示例。 Init
已被更改为采用的附加参数数字结构为和创建大小的初始值a
和b
和b
的初始值。
个人而言,我发现将main
中的原始结构创建为struct Ex **ex
然后将该地址作为三指针传递给Init
很容易,但这取决于您。你们的做法保持一致,看看下面的例子:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct Ex
{
int a;
int b;
};
/* simple copy funciton */
void Copy(struct Ex *ex1, struct Ex *ex2)
{
memcpy (ex1, ex2, sizeof (struct Ex));
}
/* arguments, address of *ex, num to create, initial values .a=va, .b=vb */
void Init(struct Ex **ex, size_t n, int va, int vb)
{
size_t i = 0;
size_t offset = sizeof **ex;
*ex = malloc (n * offset);
struct Ex *ex2 = malloc (sizeof *ex2);
ex2-> a = va;
ex2-> b = vb;
for (i = 0; i < n; i++)
Copy (*ex + i * offset, ex2);
}
int main (void) {
struct Ex *ex = NULL;
size_t offset = sizeof *ex;
size_t i = 0;
Init (&ex, 3, 5, 6); /* initialize 3 ex, with initial values of 5, 6 */
for (i = 0; i < 3; i++)
printf ("\n (ex +%2lu)->a : %d\n (ex +%2lu)->b : %d\n",
i * offset, (ex + i * offset)->a, i * offset, (ex + i * offset)->b);
return 0;
}
输出
$ ./bin/structinitcopy
(ex + 0)->a : 5
(ex + 0)->b : 6
(ex + 8)->a : 5
(ex + 8)->b : 6
(ex +16)->a : 5
(ex +16)->b : 6
不要投malloc'的'结果在C – crashmstr 2015-03-31 15:19:31
'&(*防爆+ 1) '< - 你的意思是'ex'和一个普通的'e'? – Michael 2015-03-31 15:20:23
@crashmstr你说的很对,但是OP又说了'Func.cpp'......令人困惑。 – 2015-03-31 15:20:23