C函数指针数组的定义和使用

1.使用函数指针数组来实现计算器

2.通过函数指针变量来调用对应的函数

#include <stdio.h>

int add(int a,int b){
	return a+b;
}
int sub(int a,int b){
	return a-b;
}
int mul(int a,int b){
	return a*b;
}
int div(int a,int b){
	return a/b;
}
void make_menu(){
	printf("****************************\n");
	printf("请选择菜单:\n");
	printf("1:加 2:减 3:乘 4:除 0:退出 \n");
}
/*定义函数指针数组变量
(int,int) 对应于函数指针数组 指向的函数列表
*/
int (*fun_array[4]) (int,int) = {add, sub, mul, div}; 

int main(){
	int i,j;
	int cmd;
	while(1){
		make_menu();
		scanf("%d",&cmd);
		if(cmd==0){
			break;
		}
		if(cmd>=1&&cmd<=4){
			printf("请输入2个数字:");
			scanf("%d%d",&i,&j);
			//通过函数指针数组去调用对应的函数
			int result = fun_array[cmd-1](i,j); //等同于 int result = (*fun_array[cmd-1])(i,j);
			//通过函数指针变量来调用对应的函数
			//int (*p)(int,int) = fun_array[cmd-1];
			//int  result = p(i,j);
			printf("result:%d\n",result);
		}
	}

	return 0;
}

  

原文地址:https://www.cnblogs.com/wanglijun/p/8541573.html

时间: 2024-10-01 12:52:36

C函数指针数组的定义和使用的相关文章

C语言中函数指针数组浅析

发现问题 问题分析 示例代码 发现问题 今天,在阅读Linux内核中关于socket的源代码时,遇到了下面一段代码: struct proto_ops { int family; struct module *owner; int (*release) (struct socket *sock); int (*bind) (struct socket *sock, struct sockaddr *myaddr, int sockaddr_len); int (*connect) (struct

函数指针与函数指针数组的使用方法

转自:http://blog.csdn.net/feitianxuxue/article/details/7300291 函数指针与函数指针数组的使用方法 函数指针: 函数指针包含函数在内存中的地址.数组名实际上就是数组的第一个元素在内存中的地址,类似地,函数名实际上也是执行这个函数任务的代码在内存中的起始地址. 函数指针可以传递给函数.从函数返回.保存在数组中.赋予另一个函数指针或者调用底层函数. 下面我们用数值算法accumulate讨论下函数指针的用法.accumulate是一种常用的ST

入职培训笔记记录--day9(1、指针函数与函数指针、函数指针数组 2、malloc memset 3、递归函数 4、结构体 5、共用体---》大小端 6、枚举)

1.指针函数与函数指针.函数指针数组 指针函数:返回值为指针的函数 char *fun() { char str[] = "hello world"; return str; } int main() { char *p = fun(); puts(p); return 0; } 编译时,会出现警告,返回了一个已经被释放掉的内存空间的首地址解决方法:1.static 2.char *str = "hello world"; 3.malloc 注意:使用完后要free

函数指针、函数指针数组

参考:百度百科 |函数指针|词条. 指针_函数,就不说了.自己感觉就是So-easy的.[ 声明格式:returnType *Function(arguments); ] 重点是 函数指针,以及突然冒出来的 函数指针数组;(特别说明,我习惯先写代码,再写注释:情况A:代码在左,注释向右.情况B:代码在上,注释在下.) 函数指针,我形象的描述 函数<-指针,(文中一切有问题请指正,谢谢).[声明格式: returnType(*pointer)(arguments); ] 举例: int fun(i

指针数组与数组指针 和 函数指针与函数指针数组

很容易混淆的概念其实并不难理解 1,指针数组: 看字面意思就知道这一定是一个数组,里面的原酸全部是指针 例如,定义一个简单的指针数组 char  *p[10];   //这就是一个包含十个字符指针的数组. 例: #include<stdio.h>int main(){ char *p[7]; char arr[] = "abcdef"; int i = 0; for (i = 0; i < 7; i++) {  p[i] = arr; } printf("%

函数指针,函数指针数组,函数返回值为函数指针

函数的名字就是函数的首地址:定义函数指针; int (*p)(int ) p为函数指针变量名字,int 为函数的返回值类型为int型:(int)为函数的形参类型为int型, 注:因为优先级所以要用(*p),否则就会p先和后面的()结合为int*p(int),意思就变为p(int)函数的返回值为int* 注:main2()函数中   int (*p[])(int ,int )  为一维数组,下面写错了, #include<stdio.h> #include<stdlib.h> int

转:函数指针数组的妙用(I)

转自:http://blog.sina.com.cn/s/blog_4c78b35f010008hi.html 笔者在开发某软件过程中遇到这样一个问题,前级模块传给我二进制数据,输入参数为 char* buffer 和 int length,buffer是数据的首地址,length表示这批数据的长度.数据的特点是:长度不定,类型不定,由第一个字节(buffer[0])标识该数据的类型,共有256(2的8次方)种可能性.我的任务是必须对每一种可能出现的数据类型都要作处理,并且我的模块包含若干个函数

C/C++用状态转移表联合函数指针数组实现状态机FSM

状态机在project中使用很的频繁,有例如以下常见的三种实现方法: 1. switch-case 实现.适合简单的状态机. 2. 二维状态表state-event实现.逻辑清晰.可是矩阵通常比較稀疏,并且维护麻烦. 3. 用状态转移表stateTransfer Table实现,数组大小等于状体转移边个数,易扩展: 以下用一个样例来进行具体说明,描写叙述的例如以下场景: 描写叙述对象:门 状态:开着.关着.锁着 (这里的关着指关了但未锁的状态) 事件:开门.关门.上锁.解锁 代码实现用枚举来定义

C++函数指针数组的简单使用

声明函数指针的数组类似声明一般的指针数组.接上文例子将其改进为使用函数指针的数组,代码如下: #include <iostream> using std::cout; using std::endl; //函数声明 double squared(double); double cubed(double); double sum_array(double array[],int len,double (*pfun) (double)); int main(){ double array[]={1