C++指向函数的指针用法详解

本文以实例形式展示了C++指向函数的指针用法,是深入学习C++所必须掌握的关键知识点。分享给大家供大家参考之用。具体方法如下:

函数指针

现来看看以下声明语句,看看其含义:

float (*h(int, void (*)(int)))(int); 

以下是一个变量指针的定义语句:

float* pf; 

以下是一个普通函数的声明语句:

float f(); 

请看以下声明语句:

float* g(); 

因为()的优先级高于*, 所以相当于:

float* (g()); 

g是一个函数, 返回值为float*, 参数为void

float (*h)(); 

中, h是个指针, 指向一个返回值为float的函数.
去掉h, 就是h的类型:

float (*)(); 

若要调用h所指的函数, 解引用这个指针即可:

(*h)(); 

它的缩写为(注意, 仅仅是缩写):h();
注意不能将(*h)两边的括号去掉, 去掉后,*h()等价于*(h()). ANSI C会把它认为是以下语句的缩写:

*((*h)()); 

上面的语句表示: 执行h所指向的函数, 然后解引用函数的返回值.
若h指向的函数有参数, 参数是指向函数的指针呢? 假设该参数的类型为: void (*)(int), 则h可以声明为:

float (*h)(void(*)(int)); 

已知有以下函数的声明:

float func(int); 

若要使h指向函数func, 只需要将(*h)替换func即可:

float (*h)(int); 

更进一步, h所指的函数不返回float, 而是返回指向函数的指针呢? 该指针的类型为float(*)(int).

float (*h(parameter))(int); 

其中parameter为h所指函数的参数, 假设参数类型有两个, 一个为int型, 一个类型为: void (*)(int), 则最终的结果为:

float (*h(int, void (*)(int)))(int); 

希望本文所述对大家的C++程序设计有所帮助。

你可能感兴趣的:(C++指向函数的指针用法详解)