函数指针与函数指针数组的定义与使用
2015-05-27 09:43
225 查看
函数指针与函数指针数组的定义与使用
函数指针:指向函数的指针
定义方法为
double add(double a,double b);
double sub(double a,double b);
double mul(double a,double b);
double div1(double a,double b);
double (*Func)(double,double);
参数个数,类型,返回值与所指向的函数一致,亦即这是定义了一个统配的类型。
带函数指针的函数的定义方法:
void printf(Func *f)
{
int a = 2;
int b = 3;
printf("%f",f(a,b))
}
调用方法:
printf(add);直接调用求和函数。
printf(sub);直接调用相减函数。
这种使用有些类似与面向对象的多态:多态也是将参数作为一种统配的类型,即为父类,实际传的是子类。
函数指针数组就是函数指针的数组:使用方法类似与普通的数组。只不过注意一下定义和使用方法。
定义方法如下:
double add(double a,double b);
double sub(double a,double b);
double mul(double a,double b);
double div1(double a,double b);
下面是定义方法一
double (*oper_func[])(double, double) = {
add,sub,mul,div1
};
定义方法二,使用typedef定义。
typedef double (*oper_func[])(double, double);
这样定义之后在其它函数里面可以直接使用 oper_func类型:
使用方法如下:
oper_func p= {add,sub,mul,div1};
[html] view
plaincopy
例子:
#import <Foundation/Foundation.h>
double (*oper_func[])(double, double) = {
add,sub,mul,div1
};
int main(int argc, const char * argv[])
{
int oper = 0;
int op1 = 5;
int op2 = 8;
int result = oper_func[oper](op1,op2);
printf("%d",result);
return 0;
}
double add(double a,double b)
{
return a + b;
}
double sub(double a,double b)
{
return a - b;
}
double mul(double a,double b)
{
return a * b;
}
double div1(double a,double b)
{
return a/b;
}
函数指针:指向函数的指针
定义方法为
double add(double a,double b);
double sub(double a,double b);
double mul(double a,double b);
double div1(double a,double b);
double (*Func)(double,double);
参数个数,类型,返回值与所指向的函数一致,亦即这是定义了一个统配的类型。
带函数指针的函数的定义方法:
void printf(Func *f)
{
int a = 2;
int b = 3;
printf("%f",f(a,b))
}
调用方法:
printf(add);直接调用求和函数。
printf(sub);直接调用相减函数。
这种使用有些类似与面向对象的多态:多态也是将参数作为一种统配的类型,即为父类,实际传的是子类。
函数指针数组就是函数指针的数组:使用方法类似与普通的数组。只不过注意一下定义和使用方法。
定义方法如下:
double add(double a,double b);
double sub(double a,double b);
double mul(double a,double b);
double div1(double a,double b);
下面是定义方法一
double (*oper_func[])(double, double) = {
add,sub,mul,div1
};
定义方法二,使用typedef定义。
typedef double (*oper_func[])(double, double);
这样定义之后在其它函数里面可以直接使用 oper_func类型:
使用方法如下:
oper_func p= {add,sub,mul,div1};
[html] view
plaincopy
例子:
#import <Foundation/Foundation.h>
double (*oper_func[])(double, double) = {
add,sub,mul,div1
};
int main(int argc, const char * argv[])
{
int oper = 0;
int op1 = 5;
int op2 = 8;
int result = oper_func[oper](op1,op2);
printf("%d",result);
return 0;
}
double add(double a,double b)
{
return a + b;
}
double sub(double a,double b)
{
return a - b;
}
double mul(double a,double b)
{
return a * b;
}
double div1(double a,double b)
{
return a/b;
}
相关文章推荐
- 函数指针与函数指针数组的定义与使用
- 函数指针与函数指针数组的定义与使用
- 函数指针与函数指针数组的使用方法
- 内存,指针定义使用字符串相关函数数组指针
- [c++] 函数指针和函数指针数组的使用方法
- 函数指针与函数指针数组的使用方法
- C语言学习6 :指针的定义,指针类型要合法,指针要初始化,指针做函数参数,数组和指针的通用性,指针+1所代表的空间,void * 指针,交换函数中的指针,数组和字符型指针区别,字符型指针的应用,使用指针完成字符操作函数
- 函数指针与函数指针数组的使用方法
- 关于函数指针数组与返回数组指针的函数
- 使用typedef语句定义函数类型和函数指针
- 函数指针的定义及多个函数指针的定义
- (转载)函数指针及函数指针数组的妙用
- 使用函数指针,完成一个sort()函数,能对任何类型的数组元素进行排序: 回调函数 以及 memcpy ()原型实现
- 函数指针和函数数组指针
- 使用指针从函数中返回一个数组
- 函数指针系列之函数数组指针
- 解读C语言中函数指针数组构成的复杂定义
- 关于使用定义函数来实现对于数组c中的元素进行筛选最大值最小值,计算平均值等操作
- 使用typedef简化函数指针的声明及定义
- 定义一个二维数组,写函数来实现对该二维数组求最大值。(要求,用行指针为函数形参)