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++指向函数的指针用法详解 的全部内容, 来源链接: utcz.com/z/343096.html