
之前在看代码的时候,看了函数指针的使用,大体分为如下几类:
- 做一个function list,通过指针索引调用,使得处理功能类似的函数看起来更加清晰;
- 函数指针作为另一个函数的参数,用作回调;
- linux中经常使用来达到相同接口,实现不同,如:
struct platform_driver {
int (*probe)(struct platform_device *);
int (*remove)(struct platform_device *);
void (*shutdown)(struct platform_device *);
int (*suspend)(struct platform_device *, pm_message_t state);
int (*resume)(struct platform_device *);
struct device_driver driver;
const struct platform_device_id *id_table;
bool prevent_deferred_probe;
};
实现可以是freescale的imx系列芯片的串口:
static struct platform_driver serial_imx_driver = {
.probe = serial_imx_probe,
.remove = __devexit_p(serial_imx_remove), .suspend = serial_imx_suspend,
.resume = serial_imx_resume,
.id_table = imx_uart_devtype,
.driver = {
.name = "imx-uart",
.owner = THIS_MODULE,
.of_match_table = imx_uart_dt_ids,
},
};
下面摘自一个博客:
转自:http://blog.sina.com.cn/s/blog_4d48cc5d0100xnh9.html
用途:
函数指针通常用来实现回调,也可以用来对模块调用以函数表的形式进行优化。
使用方法:
1、定义函数指针类型
使用typedef更直观更方便
// 定义一个原型为int Fun( int a );的函数指针
typedef int (*PTRFUN) ( int aPara );
typedef的功能是定义新的类型。这里定义了一种PTRFUN的类型,并定义这种类型为指向某种函数的指针,这种函数以一个int为参数并返回char类型。后面就可以像使用int,char一样使用PTRFUN了。
2、函数指针变量的定义
PTRFUN pFun; // pFun 为函数指针变量名
int (*pFun2) ( int a ); // pFun2也是函数指针变量名
3、函数指针作为函数的参数传递
// 定义回调函数
int CallBack( int a )
{
return ++a;
} // 定义回调者函数
void Caller( PTRFUN cb ) // void Caller( int (*cb) ( int ) ) // 也可这样申明
{
int nPara = ;
int nRet = cb( nPara );
} // 使用回调
void main()
{
Caller( CallBack ); // 直接使用回调函数
PTRFUN cb = CallBack; // int (*cb) ( int ); cb = CallBack;
int nRet1 = cb( ); // nRet1 = 100;
}
4、函数指针的指针使用
// 定义函数指针的指针
typedef int (**PTRPTRFUN) ( int aPara ); // 函数指针的指针作为参数
// void PtrCaller( PTRFUN* cb ) // 指针申明
// void PtrCaller( int (**cb) ( int ) ) // 原型申明
void PtrCaller( PTRPTRFUN cb )
{
int nRet = (*cb)(); // nRet = 1000;
} // 使用函数指针的指针
void main()
{
PTRFUN cb = CallBack;
PtrCaller( &cb );
}
5、函数指针数组的使用
// 函数指针数组的定义
PTRFUN fArray[]
// int (*fArray[10]) ( int ); // 原型定义
for ( int i = ; i < ; i++ )
{
fArray[i] = CallBack;
int nRet = fArray[i](i); // nRet = i+1;
}
6、函数指针的大小
既然叫指针,所以跟普通的指针一样在32位系统下大小都为4
int nSz1 = sizeof(PTRFUN); // nSz1 = 4;
int nSz2 = sizeof(PTRPTRFUN); // nSz2 = 4;
使用实例:
这里给出一个使用函数指针的简单例子:
//------------------------------------------------------
#include <stdio.h> typedef int (*PTRFUN) ( int aPara , int bPara); int func1(int Pa, int Pb);
int func2(int Pa, int Pb);
int func3(int Pa, int Pb);
int func4(int Pa, int Pb); void main()
{
int i = ;
int j = ;
PTRFUN pFuncArray[] = {func1, func2, func3, func4};
PTRFUN pFunc; for(i = ; i >= ; i --)
{
pFunc = pFuncArray[i];
printf("Output is: %d \n", (*pFunc)(i,i));
}
} int func1(int Pa, int Pb)
{
printf("func1 with input para %d, %d \n", Pa, Pb);
return Pa + Pb;
} int func2(int Pa, int Pb)
{
printf("func2 with input para %d, %d \n", Pa, Pb);
return Pa - Pb;
} int func3(int Pa, int Pb)
{
printf("func3 with input para %d, %d \n", Pa, Pb);
return Pa * Pb;
} int func4(int Pa, int Pb)
{
printf("func4 with input para %d, %d \n", Pa, Pb);
return (Pb == )? 0xffff : (Pa / Pb);
}
输出为:
func4 with input para ,
Output is: func3 with input para ,
Output is: func2 with input para ,
Output is: func1 with input para ,
Output is: