在上一篇博客中我讲解了如何利用最简单的方法来编写一个计算器代码,但由于主函数部分比较繁琐,因此我们也可以对其尝试优化,此篇博客我们运用更高阶的方法来给大家讲解如何优化上篇博客中的那种方法,使代码看起来更为简便很清楚
方法1,利用函数指针数组:
下面我直接从主函数的部分给大家讲解这个代码,其余部分和上一篇博客的代码的内容一样
定义pfArr这个数组后,对其进行初始化,数组中依次放入如图所示的五个元素,里面放了四个函数名,也就是函数的地址,那么这个数组就是一个函数指针的数组
注意:数组里面第一个元素设计成0的原因就是想要把Add函数放到下标为1的地方与每个函数的功能相对应,这样使用起来会更加方便
方法2,利用回调函数:
主函数部分:
calc函数的实现部分:
当我们把函数名传过去,在适当的情况下通过指针调用这个函数的时候,这种机制就被称为回调函数机制
总结:
此两种方法很好地改善了代码冗余的缺点,也方便我们更好地添加计算器想要实现的新的运算方式(开根号、次方、按位等等),但由于对逻辑思维能力考察的较为严格,需要我们仔细揣摩每一步代码的实际意义