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