函数指针
函数存放在内存的代码区域内,它们同样有地址。如果我们有一个int test(int a)的函数,那么,它的地址就是函数的名字,如同数组的名字就是数组的起始地址。
1、函数指针的定义方式:data_types (*func_pointer)( data_types arg1, data_types arg2, ...,data_types argn);
c语言函数指针的定义形式:返回类型 (*函数指针名称)(参数类型,参数类型,参数类型,…);
c++函数指针的定义形式:返回类型 (类名称::*函数成员名称)(参数类型,参数类型,参数类型,….);
例如: int (*fp)(int a); //这里就定义了一个指向函数(这个函数参数仅仅为一个int类型,函数返回值是int类型)的指针fp。
类成员函数指针与普通函数指针不是一码事。前者要用.*与->*运算符来使用,而后者可以用*运算符(称为“解引用”dereference,或称“间址”indirection)。
普通函数指针实际上保存的是函数体的开始地址,因此也称“代码指针”,以区别于C/C++最常用的数据指针。
而类成员函数指针就不仅仅是类成员函数的内存起始地址,还需要能解决因为C++的多重继承、虚继承而带来的类实例地址的调整问题,所以类成员函数指针在调用的时候一定要传入类实例对象。
函数指针示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
#include <stdio.h>
#include <stdlib.h>
int fun1()
{
printf ( "this is fun1 call\n" );
return 1;
}
void fun2( int k, char c)
{
printf ( "this is fun2 call:%d %c\n" , k, c);
}
int main()
{
int (*pfun1)() = NULL;
void (*pfun2)( int , char ) = NULL;
int a,b;
pfun1 = fun1; //第一种赋值方法
a = pfun1(); //第一种调用方法(推荐)
printf ( "%d\n" ,a);
b = (*pfun1)(); //第二种调用方法
printf ( "%d\n" ,b);
pfun2 = &fun2; //第二种赋值方法(推荐,因为和其他数据指针赋值方法一致)
pfun2(1, 'a' );
(*pfun2)(2, 'b' );
return 0;
}
|
函数指针作为函数参数:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include <stdio.h>
#include <stdlib.h>
void fun( int k, char c)
{
printf ( "this is fun2 call:%d %c\n" , k, c);
}
void fun1( void (*pfun)( int , char ), int a, char c)
{
pfun(a, c);
}
int main()
{
fun1(fun, 1, 'a' );
return 0;
}
// c++ 的形式差不多
|
函数指针作为函数返回值:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
// c 形式
#include <stdio.h>
#include <stdlib.h>
void fun( int k, char c)
{
printf ( "this is fun2 call:%d %c\n" , k, c);
}
//fun1 函数的参数为double,返回值为函数指针void(*)(int, char)
void (*fun1( double d))( int , char )
{
printf ( "%f\n" ,d);
return fun;
}
int main()
{
void (*p)( int , char ) = fun1(3.33);
p(1, 'a' );
return 0;
}
//c++ 形式
#include <iostream>
using namespace std;
class test
{
public :
int fun( int a, char c)
{
cout<< "this is fun call:" <<a<< " " <<c<<endl;
return a;
}
};
class test2
{
public :
// test2 的成员函数fun1,参数是double,
//返回值是test的成员函数指针int(test::*)(int, char)
int (test::*fun1( double d))( int , char )
{
cout<<d<<endl;
return &test::fun;
}
};
int main()
{
test mytest;
test2 mytest2;
int (test::*p)( int , char ) = mytest2.fun1(3.33);
(mytest.*p)(1, 'a' );
return 0;
}
|
函数指针数组:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include <stdio.h>
#include <stdlib.h>
float add( float a, float b){ return a+b;}
float minu( float a, float b){ return a-b;}
int main()
{
//定义一个函数指针数组,大小为2
//里面存放float (*)(float, float)类型的指针
float (*pfunArry[2])( float , float ) = {&add, &minu};
double k = pfunArry[0](3.33,2.22); // 调用
printf ( "%f\n" , k);
k = pfunArry[1](3.33,2.22);
printf ( "%f\n" , k);
return 0;
}
//c++ 可类比
|
typedef 简化函数指针类型:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
#include <stdio.h>
#include <stdlib.h>
float add( float a, float b)
{
printf ( "%f\n" ,a+b);
return a+b;
}
float minu( float a, float b)
{
printf ( "%f\n" ,a-b);
return a-b;
}
//用pfunType 来表示float(*)(float, float)
typedef float (*pfunType)( float , float );
int main()
{
pfunType p = &add; //定义函数指针变量
p(3.33, 2.22);
pfunType parry[2] = {&add, &minu}; //定义函数指针数组
parry[1](3.33, 2.22);
//函数指针作为参数可以定义为:void fun(pfunType p)
//函数指针作为返回值可以定义为:pfunType fun();
return 0;
}
//c++ 可类比
|
总结
以上就是本文关于C++中函数指针详解及代码示例的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:C语言实现的学生选课系统代码分享等,有什么问题可以随时留言,小编会及时回复大家的。
原文链接:http://blog.csdn.net/pipisorry/article/details/72458168