006-函数指针数组

本文详细讲解了函数指针的基础概念,包括指针函数、函数指针定义与赋值,以及函数指针数组的使用。通过实例演示了如何声明、赋值和调用函数指针,并展示了函数指针在实际编程中的应用场景,适合深入理解C语言高级特性。
摘要由CSDN通过智能技术生成

函数指针数组

1.指针函数

指针函数是指 带指针的函数,即本质是一个函数。
函数都有返回类型(如果不返回值,则为无值型),只不过指针函数返回类型是某一类型的指针。
其定义格式如下所示:

返回类型标识符 *返回名称(形式参数表)
{ 
	函数体
} 

返回类型可以是任何基本类型和复合类型。返回指针的函数的用途十分广泛。事实上,每一个函数,即使它不带有返回某种类型的指针,它本身都有一个入口地址,该地址相当于一个指针。比如函数返回一个整型值,实际上也相当于返回一个指针变量的值,不过这时的变量是函数本身而已,而整个函数相当于一个"变量"。

2.函数指针

"函数指针"是指向函数的指针变量,因而"函数指针"本身首先应是指针变量,只不过该指针变量指向函数。这正如用指针变量可指向整型变量、字符型、数组一样,这里是指向函数。
C在编译时,每一个函数都有一个入口地址,该入口地址就是函数指针所指向的地址。有了指向函数的指针变量后,可用该指针变量调用函数,就如同用指针变量可引用其他类型变量一样,在这些概念上一致的。函数指针有两个用途:调用函数和做函数的参数。

函数指针的说明方法为:

函数类型 (*指针变量名)(形参列表);

“函数类型"说明函数的返回类型,由于”()“的优先级高于”*", 所以指针变量名外的括号必不可少,后面的"形参列表"表示指针变量指向的函数所带的参数列表。

例如:

int (*f)(int x);

double(*ptr)(double x);

在定义函数指针时请注意:

  • 函数指针和它指向的函数的参数个数和类型都应该是—致的;

  • 函数指针的类型和函数的返回值类型也必须是一致的。

函数指针的赋值

函数名和数组名一样代表了函数代码的首地址,因此在赋值时,直接将函数指针指向函数名就行了。

int func(int x);    /* 声明一个函数 */
int (*f)(int x);    /* 声明一个函数指针 */
f = func;           /* 将func函数的首地址赋给指针f */

赋值时函数func不带括号,也不带参数,由于func代表函数的首地址,因此经过赋值以后,指针f就指向函数func(x)的代码的首地址。

与其他指针变量相类似,如果指针变量pi是指向某整型变量i的指针,则*p等于它所指的变量i;如果pf是指向某浮点型变量f的指针,则*pf就等价于它所指的变量f。同样地,*f是指向函数func(x)的指针,则*f就代表它所指向的函数func。所以在执行了f = func;之后,(*f)和func代表同一函数。

由于函数指针指向存储区中的某个函数,因此可以通过函数指针调用相应的函数。
如何用函数指针调用函数,它应执行下面三步:

首先,要说明函数指针变量。

例如:int (*f)(int x);

其次,要对函数指针变量赋值。

例如: f = func;
(func(x)必须先要有定义)

最后,要用(*指针变量)(参数表);
调用函数。

例如:(*f)(x);
(x必须先赋值) 

例1

int max(int x, int y)
{
    return(x > y ? x : y);
} 
 
int  main(void)
{
    int a, b, c;
    int (*ptr)(int, int);
    scanf("%d,%d", &a, &b);
    ptr = max;
    c = (*ptr)(a, b);
    printf("a=%d,b=%d,max=%d", a, b, c);
    return 0;
}

例2

void FileFunc()
{
    printf("FileFunc\n");
} 
 
void EditFunc()
{
    printf("EditFunc\n");
} 
 
int main(void)
{
    void (*funcp)();
    funcp = FileFunc;
    (*funcp)();
    funcp = EditFunc;
    (*funcp)();
}

3.函数指针数组

函数指针数组是一个其元素是函数指针的数组。那么也就是说,此数据结构是一个数组,且其元素是一个指向函数入口地址的指针。
根据分析:首先说明是一个数组:数组名[]
其次,要说明其元素的数据类型指针:*数组名[].
再次,要明确这每一个数组元素是指向函数入口地址的指针:函数返回值类型 ( *数组名[ ] )( ).
请注意,这里为什么要把"*数组名[]"用括号扩起来呢?因为圆括号和数组说明符的优先级是等同的,如果不用圆括号把指针数组说明表达式扩起来,根据圆括号和方括号的结合方向,那么 *数组名[]() 说明的是什么呢?是元素返回值类型为指针的函数数组。有这样的函数数祖吗?不知道。所以必须括起来,以保证数组的每一个元素是指针。

#include "stdio.h"
int add1(int a1, int b1);
int add2(int a2, int b2); 
 
int main(int argc, char *argv[])
{
    int numa1 = 1, numb1 = 2;
    int numa2 = 2, numb2 = 3;
    int (*op[2])(int a, int b);
    op[0] = add1;
    op[1] = add2;
    printf("%d %d\n", op[0](numa1, numb1), op[1](numa2, numb2));
    getch();
} 
 
int add1(int a1, int b1)
{
    return a1 + b1;
} 
 
int add2(int a2, int b2)
{
    return a2 + b2;
}

4.综合

再给出常用的C变量的定义方式:
a) 一个整型数(An integer)
b) 一个指向整型数的指针(A pointer to an integer)
c) 一个指向指针的的指针,它指向的指针是指向一个整型数(A pointer to a pointer to an integer)
d) 一个有10个整型数的数组(An array of 10 integers)
e) 一个有10个指针的数组,该指针是指向一个整型数的(An array of 10 pointers to integers)
f) 一个指向有10个整型数数组的指针(A pointer to an array of 10 integers)
g) 一个指向函数的指针,该函数有一个整型参数并返回一个整型数(A pointer to a function that takes an integer as an argument and returns an integer)
h) 一个有10个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数( An array of ten pointers to functions that take an integer argument and return an integer)

答案是:
a) int a;               // An integer
b) int *a;              // A pointer to an integer
c) int **a;             // A pointer to a pointer to an integer
d) int a[10];           // An array of 10 integers
e) int *a[10];          // An array of 10 pointers to integers
f) int (*a)[10];        // A pointer to an array of 10 integers
g) int (*a)(int);       // A pointer to a function a that takes an integer argument and returns an integer
h) int (*a[10])(int);   // An array of 10 pointers to functions that take an integer argument and return an integer
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值