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

时间:2021-05-20

本文以实例形式展示了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++程序设计有所帮助。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章