问题描述
我正在尝试学习函数指针,我只想制作 3 个具有指向它们的指针的函数,这些函数用于我通过函数指针数组调用的其他 2 个函数中。代码没有给出任何错误,但我收到的是地址而不是值。我尝试取消引用等,但没有任何变化。我确信我忽略了一些简单的事情,但我不知道该怎么做,或者我的错误在哪里。
显式转换就在那里,因为我只是在玩它,没有特别的原因。
#include <stdio.h>
#include <stdlib.h>
unsigned int par1(void)
{
return 5;
}
unsigned int par2(void)
{
return 6;
}
unsigned int par3(void)
{
return 7;
}
const unsigned int x = 10;
typedef unsigned int (*parPtr)(void);
parPtr parP1 = &par1;
parPtr parP2 = &par2;
parPtr parP3 = &par3;
/** typedef for sum() and scad() */
typedef int (*sumscadPtr)(parPtr,parPtr);
sumscadPtr sumscadPtrArr[2];
int sum(parPtr,parPtr);
int scad(parPtr,const unsigned int);
void allocate_array_of_pointers(void)
{
sumscadPtrArr[0] = ∑
sumscadPtrArr[1] = &scad;
}
// should return 11
int sum(parPtr para,parPtr parB)
{
unsigned int value1 = *para;
printf("\n%d\n",value1);
unsigned int value2 = *parB;
printf("\n%d\n",value2);
return (int)value1 + (int)value2;
}
// should return 3
int scad(parPtr para,unsigned const int b)
{
unsigned int value1 = para;
// This is just a simple check in case i might change the const value in the future
if((int)value1 > (int)b)
return (int)value1 - (int)b;
else
return (int)b - (int)value1;
}
int main()
{
allocate_array_of_pointers();
int sumVal = sumscadPtrArr[0](&par1,&par2);
int scadVal = sumscadPtrArr[1](&par3,x);
printf("\nsumVal is :%d\n",sumVal);
printf("\nscadVal is :%d\n",scadVal);
int a = *parP1;
printf("\n%d\n",a);
return 0;
}
解决方法
您的代码 failed 编译时出现这些错误:
main.cpp:42:24: error: invalid conversion from 'int (*)(parPtr,unsigned int)' {aka 'int (*)(unsigned int (*)(),unsigned int)'} to 'sumscadPtr' {aka 'int (*)(unsigned int (*)(),unsigned int (*)())'} [-fpermissive]
42 | sumscadPtrArr[1] = &scad;
这很明显,因为您将指向具有不同函数签名的函数的指针存储在 sumscadPtrArr[1]
中而不是 parPtr
。
然后:
error: invalid conversion from 'parPtr' {aka 'unsigned int (*)()'} to 'unsigned int' [-fpermissive]
51 | unsigned int value1 = *parA;
以及将 *
应用到 parPtr
的所有此类调用的类似错误,后者用于将 parPtr
分配给 unsigned int
。正确的做法是
unsigned int value1 = parA();
函数指针可以通过两种方式解除引用:
(*fnPtr)()
fnPtr()
您尝试使用 sumscadPtrArr
创建的函数指针*数组/表理想情况下应该包含相同类型的函数,或者您可以使用以下内容创建结构:
struct fPtrTablle {
int (*sumFn)(parPtr,parPtr);
int (*scadFn)(parPtr,const unsigned int);
};
struct fPtrTablle FnTable = { sum,scad};
void initFnTable(void)
{
FnTable.sumFn = ∑
FnTable.scadFn = &scad;
}
然后从 main()
调用它:
initFnTable();
int sumVal = FnTable.sumFn(&par1,&par2);
int scadVal = FnTable.scadFn(&par3,x);
完整的可编译程序here。