1.函数指针数组
存放函数指针的数组
格式: int (*parr1[10])();
解释:parr1首先和[]结合,说明parr1是数组,接着再和int(*)()结合,说明类型是函数指针。
2.简易版计算器
#include<stdio.h> int Add(int x, int y) { return x + y; } int Sub(int x, int y) { return x - y; } int Mul(int x, int y) { return x * y; } double Div(int x, int y) { return x*1.0/ y; } void menu() { printf("***********************************\n"); printf(" 1.Add 2.Sub \n"); printf(" 3.Mul 4.Div \n"); printf(" 0.Exit \n"); printf("***********************************\n"); } int main() { int inpute = 0; int x, y; do { menu(); scanf("%d", &inpute); switch (inpute) { case 1: { scanf("%d %d", &x, &y); int ret = Add(x, y); printf("%d\n", ret); break; } case 2: { scanf("%d %d", &x, &y); int ret = Sub(x, y); printf("%d\n", ret); break; } case 3: { scanf("%d %d", &x, &y); int ret = Mul(x, y); printf("%d\n", ret); break; } case 4: { scanf("%d %d", &x, &y); double ret = Div(x, y); printf("%lf\n", ret); break; } case 0: { printf("退出成功!\n"); break; } default: { printf("输入错误请重新输入!\n"); break; } } } while (inpute); return 0; }
3.优化版计算器
简易版计算器在每个case语句部分会有大量的重复,这种被称为代码冗余,而我们可以通过函数指针数组来减少代码量,从而也能实现同样的功能。该代码只是简化了代码量,并没有优化其他部分
int Add(int x, int y) { return x + y; } int Sub(int x, int y) { return x - y; } int Mul(int x, int y) { return x * y; } int Div(int x, int y) { return x * 1.0 / y; } //简易的菜单 void menu() { printf("***********************************\n"); printf(" 1.Add 2.Sub \n"); printf(" 3.Mul 4.Div \n"); printf(" 0.Exit \n"); printf("***********************************\n"); } int main() { int (*pf[5])() = { 0,Add,Sub,Mul,Div }; //利用函数指针数组来存储函数的地址 int inpute = 0;//用于选择什么运算 int x, y; //操作数 int ret; //用于接受返回值 do { menu(); scanf("%d", &inpute); if (inpute >= 1 && inpute <= 4) { printf("请输入计算的两个操作数:"); scanf("%d %d", &x, &y); ret = (pf[inpute])(x, y); printf("%d\n", ret); } else if(inpute==0) { printf("退出成功!\n"); break; } else { printf("选择错误,请重新输入:"); } } while (inpute); }
总结:函数指针数组虽然用的很少,但是有时候能帮助我们简化一定的代码量。
以上是函数指针数组的内容,如有问题,恳请大佬指点💖