回调函数的使用
这里我参考的它的想法,理解得很好
1. 为啥需要使用回调函数
有没有碰到一种情况,就是应用程序需要采集硬件层的数据,比如串口接收数据,按键采集、ADC值采集。
这种硬件层的数据怎么通知应用层来拿,或者怎么主动给它?
我们以往最简单粗暴的方式是不是就是用一个全局变量,比方说硬件层串口接收到数据来了,那么我们把数据丢到数组里,然后把接收完成全局变量标志位置1。
比方说全局变量名为RcvFlag,然后应用层程序会轮询判断RcvFlag==1?是的话就开始把数组里的数据取出来解析。
很多人就会说了,你看我用这种方法照样能实现功能啊,为什么还要学习别的架构。
这样做当然可以实现功能,但是会存在移植性很差的问题。
比如说你们老板让你把这个串口的硬件层封装起来给客户用,但不能让客户看到你实现的源码,只提供接口(函数名)给对方用。
那么这时候难道你要告诉客户先判断哪个变量为1,然后再取哪个数组的数据这么LOW的做法吗?
那么如果是懂行的客户一定会怀疑你们公司的技术实力是不是小学生水平。
那怎样做才会既方便又专业呢? 这里我们就需要用到回调函数啦。
2. 如何使用回调函数
回调函数的核心:
- 把数据从1个.c文件传递到另一个.c文件,而不用全局变量共享数据这么low的方法
- 对于这种数据传递方式,回调函数更利于代码的封装。