Email : hahayacoder@gmail.com
背景:
最近工作中函数指针用得比较多,以前函数指针用得很少,一知半解的,所以深入学习下函数指针
区别:
先区别下面两种声明:
(1)int *func(int x, int y); 由于( )的优先级高于*,所以func先与后面的()相结合,即func是一个函数,它有两个int型的形参,返回一个指向int的指针
(2)int (*func)(int x, int y); 通过()强行使func与*相结合,也就意味着,func是一个指针,接着与后面的( )结合,说明该指针指向的是一个函数,然后再与前面的int结合,也就是说,该函数的返回值是int。由此可见,func是一个指向有两个int形参且返回值为int的函数的指针。
定义:
函数指针是指向函数的指针,所以函数指针本身就是指针,只不过该指针变量指向函数。这正如用指针变量可指向整型变量、字符型、数组一样,这里是指向函数。如前所述,C在编译时,每一个函数都有一个入口地址,该入口地址就是函数指针所指向的地址。有了指向函数的指针变量后,可用该指针变量调用函数,就如同用指针变量可引用其他类型变量一样,在这些概念上是一致的。函数指针有两个用途:调用函数和做函数的参数。
使用方式:
int func(int x); /* 声明一个函数 */
int (*f) (int x); /* 声明一个函数指针 */
f=func; /* 将func函数的首地址赋给指针f */
赋值时函数func不带括号,也不带参数,由于func代表函数的首地址,因此经过赋值以后,指针f就指向函数func(x)的代码的首地址。
//main.cpp
#include <iostream>
using namespace std;
int max(int x, int y)
{
return x > y ? x : y;
}
int main(int argc, char *argv[])
{
//声明一个函数指针
int (*ptr)(int x, int y);
// //给函数指针ptr赋值
ptr = max;
cout << ptr(1, 2) << endl;
return 0;
}
ptr是指向函数的指针变量,所以可把函数max()赋给ptr作为ptr的值,即把max()的入口地址赋给ptr,以后就可以用ptr来调用该函数,实际上ptr和max都指向同一个入口地址,不同就是ptr是一个指针变量,不像函数名称那样是死的,它可以指向任何函数,就看你想怎么做了。在程序中把哪个函数的地址赋给它,它就指向哪个函数。而后用指针变量调用它,因此可以先后指向不同的函数。不过注意,指向函数的指针变量没有++和--运算,用时要小心。
但是该程序有可能在某些编译器中编译不通过,所以下面做法才是常用做法
(1) 定义函数指针类型
typedef int (*MyFunc)(int x, int y);
(2) 声明刚定义的类型变量、赋值
MyFunc func = max;
//main.cpp
#include <iostream>
using namespace std;
int max(int x, int y)
{
return x > y ? x : y;
}
//定义函数指针类型MyFunc
typedef int (*MyFunc)(int x, int y);
int main(int argc, char *argv[])
{
//声明函数指针类型变量、赋值
MyFunc func = max;
cout << func(1, 2) << endl;
return 0;
}