指针,任何一个计算机语言都少不了的好东西。特殊问题,特殊对待。函数指针就是这么一个特殊的例子。比如:
void Run(void)
{
PORTB = ~PORTB;
}
这个函数我们可以直接在main()里调用它,也可以使用指针。如下所示:
void (*fun)(void);
int main()
{
fun = Run;
fun();
return 0;
}
使用指针有很多优点,关于指针的基本概念可以参考的第十六课:http://www.51hei.com/mcuteach/133.html ,如果我们定义了一个指针数组,就可以同时调用多个已知的函数,在不需要调用的时候再将它删除。特别是在C++里,如果定义了一个全局的class,那么我们就可以在构造函数里向指针数组添加一个指针,这个指针指向main()里需要反复调用的程序,那么在编写大型程序的时候维护起来就相当轻松了。下面是我在使用C++类定义的一个函数回调类,它是一个全局的类,在main()之前就已经定义了。
typedef void (*PROC)(MESSAGE_TYPE &style,MESSAGE ¶m); //定义函数类型,形参为MESSAGE枚举 typedef void (*HANDLER)(void); class Delegate { protected: PROC proc[PROC_SIZE]; HANDLER pRun[PROC_SIZE]; static void NULLFUNCTION0(void) { } static void NULLFUNCTION2(MESSAGE_TYPE &style,MESSAGE ¶m) { } public: bool add(PROC fun)//添加回调函数 { char i; for(i = 0 ; i < PROC_SIZE ; i++) { if(proc[i] == NULLFUNCTION2) { proc[i] = fun; return true; } } return false; } bool add(HANDLER fun)// 添加实时运行函数 { char i; for(i = 0 ; i < PROC_SIZE ; i++) { if(pRun[i] == NULLFUNCTION0) { pRun[i] = fun; return true; } } return false; } void clearProc()//清除函数指针 { char i; for(i = 0; i < PROC_SIZE ; i++) { proc[i] = NULLFUNCTION2; } } void clearRun() { char i; for(i = 0; i < PROC_SIZE ; i++) { pRun[i] = NULLFUNCTION0; } } bool remove(PROC fun)//删除最后一个匹配的回调 { char i; i = PROC_SIZE ; while( i-- ) { if(proc[i] == fun) { proc[i] = NULLFUNCTION2; return true; } } return false; } bool remove(HANDLER fun)// 删除最后一个匹配的回调 { char i; i = PROC_SIZE ; while( i-- ) { if(pRun[i] == fun) { pRun[i] = NULLFUNCTION0; return true; } } return false; } bool removeAll(PROC fun)//删除所有匹配的回调 { char i; bool deled = false; for(i = 0; i < PROC_SIZE; i++) { if(proc[i] == fun) { proc[i] = NULLFUNCTION2; deled = true; } } return deled; } void selectProc(PROC fun)// 选择回调 { clearProc(); add(fun); } void selectRun(HANDLER fun)// 选择回调 { clearRun(); add(fun); } void send(MESSAGE_TYPE type,MESSAGE param = WM_NULL)// 发送消息 { char i; for(i = 0 ; i < PROC_SIZE ; i++) { if(proc[i] != NULLFUNCTION2) { proc[i](type,param); if(param == WM_HANDLED) return ; } } } void Run()//运行 { char i; for(i = 0 ; i < PROC_SIZE ; i++) { if(pRun[i] != NULLFUNCTION0) { pRun[i](); } } } void operator = (PROC fun) { selectProc(fun); } void operator = (HANDLER fun) { selectRun(fun); } void operator += (PROC fun) { add(fun); } void operator += (HANDLER fun) { add(fun); } void operator -= (HANDLER fun) { remove(fun); } void operator -= (PROC fun) { remove(fun); } Delegate() { clearProc(); clearRun(); } }; Delegate dg;
上一篇:在编程中基于事件驱动的好处
下一篇:于GPS_CHECKTIAMER串口收发程序
推荐阅读最新更新时间:2024-03-16 13:06
设计资源 培训 开发板 精华推荐
- AMD推出第二代Versal Premium系列产品:首款PCIe 6.0和CXL 3.1的SoC FPGA
- 红帽宣布达成收购Neural Magic的最终协议
- 5G网速比4G快但感知差!邬贺铨:6G标准制定应重视用户需求
- SEMI报告:2024年第三季度全球硅晶圆出货量增长6%
- OpenAI呼吁建立“北美人工智能联盟” 好与中国竞争
- 传OpenAI即将推出新款智能体 能为用户自动执行任务
- 尼得科智动率先推出两轮车用电动离合器ECU
- ASML在2024 年投资者日会议上就市场机遇提供最新看法
- AMD将裁员4%,以在人工智能芯片领域争取更强的市场地位
- Arm:以高效计算平台为核心,内外协力共筑可持续未来