C++ Function call via an object with public member pointer to function, without using dereference operator(通过带有指向函数的公共成员指针的对象调用C++函数,而不使用取消引用运算符)
问题描述
好的,我认为这个标题已经足够描述了(但是令人困惑,抱歉)。
我正在阅读此库:Timer1。
在头文件中,有一个指向如下函数的公共成员指针:
class TimerOne
{
public:
void (*isrCallback)(); // C-style ptr to `void(void)` function
};
存在TimerOne类的实例化对象,名为";Timer1";。
Timer1按如下方式调用函数:
Timer1.isrCallback();
这怎么正确?我熟悉使用取消引用运算符通过函数指针调用函数。
例如:
(*myFunc)();
所以我本以为通过该对象进行的上述调用更类似于:
(*Timer1.isrCallback)();
那么,作为对象的独立函数指针和成员,通过函数指针调用函数有哪些可接受的选项?
另请参阅:
- [非常有用!]Typedef function pointer?
答案摘要:
这些都是调用函数指针的有效方法:
myFuncPtr();
(*myFuncPtr)();
(**myFuncPtr)();
(***myFuncPtr)();
// etc.
(**********************************f)(); // also valid
推荐答案
可以使用函数指针执行的操作。
1:第一个是通过显式取消引用调用函数:
int myfunc(int n)
{
}
int (*myfptr)(int) = myfunc;
(*myfptr)(nValue); // call function myfunc(nValue) through myfptr.
2:第二种方式是隐式取消引用:
int myfunc(int n)
{
}
int (*myfptr)(int) = myfunc;
myfptr(nValue); // call function myfunc(nValue) through myfptr.
正如您所看到的,隐式取消引用方法看起来就像一个普通的函数调用--这是您所期望的,因为函数只是隐式可转换为函数指针!!
在您的代码中:
void foo()
{
cout << "hi" << endl;
}
class TimerOne
{
public:
void(*isrCallback)();
};
int main()
{
TimerOne Timer1;
Timer1.isrCallback = &foo; //Assigning the address
//Timer1.isrCallback = foo; //We could use this statement as well, it simply proves function are simply implicitly convertible to function pointers. Just like arrays decay to pointer.
Timer1.isrCallback(); //Implicit dereference
(*Timer1.isrCallback)(); //Explicit dereference
return 0;
}
这篇关于通过带有指向函数的公共成员指针的对象调用C++函数,而不使用取消引用运算符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:通过带有指向函数的公共成员指针的对象调用C++函数,而不使用取消引用运算符
- 将函数的返回值分配给引用 C++? 2022-01-01
- OpenGL 对象的 RAII 包装器 2021-01-01
- 如何提取 __VA_ARGS__? 2022-01-01
- XML Schema 到 C++ 类 2022-01-01
- GDB 不显示函数名 2022-01-01
- DoEvents 等效于 C++? 2021-01-01
- 从父 CMakeLists.txt 覆盖 CMake 中的默认选项(...)值 2021-01-01
- 将 hdc 内容复制到位图 2022-09-04
- 使用 __stdcall & 调用 DLLVS2013 中的 GetProcAddress() 2021-01-01
- 哪个更快:if (bool) 或 if(int)? 2022-01-01