微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

函数指针代码未正确执行

如何解决函数指针代码未正确执行

我正在尝试学习函数指针,我只想制作 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] = &sum;
    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();

函数指针可以通过两种方式解除引用:

  1. (*fnPtr)()
  2. fnPtr()

您尝试使用 sumscadPtrArr 创建的函数指针*数组/表理想情况下应该包含相同类型的函数,或者您可以使用以下内容创建结构:

struct fPtrTablle {
    int (*sumFn)(parPtr,parPtr);
    int (*scadFn)(parPtr,const unsigned int);
};

struct fPtrTablle FnTable = { sum,scad};

void initFnTable(void)
{
    FnTable.sumFn =  &sum;
    FnTable.scadFn = &scad;
}

然后从 main() 调用它:

initFnTable();

int sumVal = FnTable.sumFn(&par1,&par2);
int scadVal = FnTable.scadFn(&par3,x);

完整的可编译程序here

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。