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
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- C++,'if' 表达式中的变量声明 2021-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04
- 运算符重载的基本规则和习语是什么? 2022-10-31
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17
- 设计字符串本地化的最佳方法 2022-01-01
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01