我是指针数组(将函数放入数组)并使用malloc为其分配内存的新手。你能帮我写这段代码吗?具有功能:int comp_int(int a, int b); int comp_int_abs(int a, int b); int comp_int_length(int a, int b); int comp_int_digits_sum(int a, int b);
并希望将指向这些函数的指针放在指针数组中。首先,希望为数组动态分配内存,并将函数的指针放入其中。被困在这个地方,我做错了什么?
int (**funcs)(int, int) = malloc(4*sizeof(int));
if(!*funcs)
{
printf("Failed to allocate memory");
return 8;
}
*funcs={add_int, sub_int, div_int, mul_int};
首先,为什么要分配动态内存?
如果您使用普通数组,事情会变得简单一些:
int (*funcs[])(int, int) = {
comp_int,
comp_int_abs,
comp_int_length,
comp_int_digits_sum,
};
如果要使用动态分配,需要注意一些事项。
int (**funcs)(int, int) = malloc(4 * sizeof *funcs);
首先,我们需要分配适量的内存。通过乘以取消引用指针的大小,我们不必担心动态数组的元素类型。(但是如果我们想手动编写类型,它将是sizeof (int (*)(int, int))
,而不是像代码中那样sizeof (int)
;数组的元素是指向函数的指针,而不是整数。
然后我们检查分配失败:
if (!funcs) {
注意:我们检查指针本身(funcs
),而不是动态数组的第一个元素(可能不存在!),如您的代码(*funcs
)。如果malloc
失败并返回NULL
,则!*funcs
将尝试取消引用空指针,这很可能会使您的程序崩溃。
fprintf(stderr, "Failed to allocate memoryn");
错误消息转到stderr
,而不是stdout
。行由'n'
终止。
return 8;
}
由于我们这里没有真正的数组,所以我们不能使用初始化语法。特别是,= {
在赋值表达式中无效。
最直接的解决方案是手动分配元素:
funcs[0] = comp_int;
funcs[1] = comp_int_abs;
funcs[2] = comp_int_length;
funcs[3] = comp_int_digits_sum;
这有点容易出错,因为我们必须手动指定每个索引。但是,我们可以将其与上面的"正常数组"代码结合使用:
int (*const funcs_init[])(int, int) = {
comp_int,
comp_int_abs,
comp_int_length,
comp_int_digits_sum,
};
int (**funcs)(int, int) = malloc(sizeof funcs_init);
if (!funcs) { ... }
memcpy(funcs, funcs_init, sizeof funcs_init);
我们只是像往常一样初始化我们的数组(这里称为funcs_init
),然后使用memcpy
将内容复制到动态分配的内存中。
首先,将分配从:
int (**funcs)(int, int)=malloc(4*sizeof(int));
自
int (**funcs)(int, int)=malloc(4*sizeof(*funcs));
改变
*funcs={add_int, sub_int, div_int, mul_int};
自
funcs[0]=add_int;
funcs[1]=sub_int;
funcs[2]=div_int;
funcs[3]=mul_int;
带大括号 {} 的表示法只能在初始化时使用,而不能在赋值时使用。如果使用数组而不是指针,则可以执行以下操作:
int (*funcs[4])(int, int)={add_int, sub_int, div_int, mul_int};