我是C编程的新手,我尝试创建一个包含char和函数指针的结构,这就是问题。
我想更改该代码:
switch (flag) {
case 'd':
case 'i':
return (my_put_nbr(va_arg(ap, int)));
case 'p':
return (my_putstr("0x") + my_l_base_changer(va_arg(ap, char *),
16));
case 'u':
return (my_put_unbr(va_arg(ap, unsigned int)));
case 'b':
return (my_u_base_changer(va_arg(ap, unsigned int), 2, 0));
case 'o':
return (my_u_base_changer(va_arg(ap, unsigned int), 8, 0));
case 'x':
return (my_u_base_changer(va_arg(ap, unsigned int), 16, 0));
case 'X':
return (my_u_base_changer(va_arg(ap, unsigned int), 16, 1));
default:
return (0);
}
在那种代码中:
typedef struct fptr
{
char op;
int (*ptr)(va_list);
} fptr;
fptr fptrs[]=
{
{ 's', ft_print_nb_spec },
{ 'S', ft_print_nb_up },
{ 0, NULL }
};
int i = 0;
while (fptrs[i++].op != flag && fptrs[i].op != 0);
if (fptrs[i].op != 0)
{
fptrs[i].ptr();
}
我的struct包含一个函数指针,指向获取不同原型的函数
我的结构是这样的:
typedef struct action {
char flag;
void *function;
} action;
我的代码就是那样的错误:
action registers[] = {
{ 'd', (int *)(*my_put_nbr)(int) },
{ 'i', (int)(*my_put_nbr)(va_arg(ap, int)) },
{ 'p', (int)(*my_print_ptr)(va_list ap) },
{ 'u', (int)(*my_put_unbr)(va_arg(ap, unsigned int)) },
{ 'b', (int)(*my_u_base_changer)(va_arg(ap, unsigned int), 2, 0) },
{ 'o', (int)(*my_u_base_changer)(va_arg(ap, unsigned int), 8, 0) },
{ 'x', (int)(*my_u_base_changer)(va_arg(ap, unsigned int), 8, 0) },
{ 'X', (int)(*my_u_base_changer)(va_arg(ap, unsigned int), 8, 1) },
{ 0, NULL }
};
当我运行gcc时得到了:
flag_nbr.c:13:28: error: expected expression before ‘int’
{ 'd', (int)(my_put_nbr)(int) },
^~~
flag_nbr.c:13:28: error: missing initializer for field ‘function’ of ‘printf_action {aka struct <anonymous>}’ [-Werror=missing-field-initializers]
In file included from flag_nbr.c:8:0:
../include/my.h:21:8: note: ‘function’ declared here
void *function;
^~~~~~~~
flag_nbr.c:14:10: error: initialization makes pointer from integer without a cast [-Werror=int-conversion]
{ 'i', (int)(my_put_nbr)(va_arg(ap, int)) },
^
我不明白这个错误......
答案 0 :(得分:2)
如有疑问,请检查数据类型!!
您将变量定义为指向action
类型的指针数组。
你在初始化器中传递的是括号括起的列表,它肯定与指向action
类型的指针不匹配。
换句话说,你尝试传递一个括号括起来的列表,同时指望一个指针。现在,指针的初始化器应该是奇异值(或标量,因为你可以称之为),因此支撑外壳不是强制性的。
虽然这完全有效,但大多数情况下,这可能是由于您编写了一些您不打算写的内容(例如:您的案例!!)而导致gcc
产生警告的问题对此。
您可能希望更改数组类型以保存action
类型的结构,而不是指向它们的指针。
答案 1 :(得分:0)
您正在使用typedef为已经具有相同名称的结构命名,请检查。 这可能不是主要原因。