C函数声明中的混淆语句



我正在STM32 MCU上进行USB驱动程序的代码实现。我对C语言的理解有点有限,我遇到了这个我不清楚的函数定义

static enum usbd_request_return_codes cdcacm_control_request(
usbd_device *usbd_dev __attribute__((unused)),
struct usb_setup_data *req,
uint8_t **buf __attribute__((unused)),
uint16_t *len,
void (**complete)
(
usbd_device *usbd_dev,
struct usb_setup_data *req
) __attribute__((unused))
)

我不理解函数声明中的最后一个参数,它似乎实际上是在为该参数定义另一个函数,并使用奇怪的两个星号作为参数。有人能解释一下这是什么,以及在实际的函数调用中如何使用它吗?

void (**complete)
(
usbd_device *usbd_dev,
struct usb_setup_data *req
) __attribute__((unused))

是指向函数指针的指针的声明。函数具有返回类型void和两个参数。

为了更清楚,请考虑下面的演示程序。

#include <stdio.h>
void f( int x, int y )
{
printf( "x + y = %lldn", ( long long int )x + y );
}
void g( int x, int y, void ( **fp )( int, int ) )
{
( *fp )( x, y );
}
int main(void) 
{
void ( *fp )( int, int ) = f;

g( 10, 20, &fp );

return 0;
}

程序输出为

x + y = 30

如果没有更广泛的上下文,就很难说为什么要使用指向函数的指针。也许是因为该参数是一个输出参数。或者可以有一个动态分配的指向函数的指针数组。

最新更新