如何解决C/C++返函数指针的函数声明

7 篇文章 0 订阅

  今天在博客园上看到一篇如何解决C/C++返函数指针的函数声明的文章,我也来说说我的方法。

int (*(*pf())())() {
    return nullptr;
}

从左到右找到最里面的括号,然后一步一步替换。

1 首先找到的是pf(),这是一个函数,则替换为p1,结果如下:

p1 pf();
int (*(*p1)())();

2 再从左向右找,找到一个函数指针,替换为p2,结果如下:

p2 (*p1)();

int (*p2)();

3 剩下的就是一个函数指针了

int (*p2)();


现用typedef 定义一下,结果如下:

typedef int (*p2)();

typedef p2 (*p1)();

p1 pf();


注意:第一次找到的肯定是最内部的一个函数;从第二次找就是找指向一个函数的指针。



 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在CLR/C++中,可以使用委托来实现函数指针的功能委托是一种类型安全的函数指针,可以用于引用和调用函数。以下是使用CLR/C++定义和使用委托的示例: ```cpp #include <iostream> // 定义委托类型 delegate void MyDelegate(int); // 示例函数1 void Function1(int value) { std::cout << "Function1 called with value: " << value << std::endl; } // 示例函数2 void Function2(int value) { std::cout << "Function2 called with value: " << value << std::endl; } int main() { // 声明委托变量 MyDelegate^ myDelegate; // 将委托绑定到函数1 myDelegate = gcnew MyDelegate(&Function1); // 调用委托,实际上调用了函数1 myDelegate->Invoke(10); // 将委托绑定到函数2 myDelegate = gcnew MyDelegate(&Function2); // 调用委托,实际上调用了函数2 myDelegate->Invoke(20); return 0; } ``` 在这个示例中,我们首先使用`delegate`关键字定义了一个委托类型`MyDelegate`,它可以引用一个接受一个`int`参数并回`void`的函数。 然后,我们定义了两个示例函数`Function1`和`Function2`,它们符合上述的委托类型。 在`main`函数中,我们声明了一个名为`myDelegate`的委托变量。 我们将`myDelegate`绑定到`Function1`并调用它,然后将`myDelegate`绑定到`Function2`并再次调用它。 使用委托时,可以使用`Invoke`方法来调用委托,实际上是在调用委托所绑定的函数。 请注意,CLR/C++中的委托与传统的C++函数指针有所不同。委托是一种引用类型,需要使用`gcnew`关键字进行实例化,并使用`^`符号来声明委托变量。委托还提供了更多的灵活性和功能,如多播委托和异步委托等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值