为什么这种模式不能在成员函数中使用?
Why such pattern can't be used in a member function?
我在全局函数中使用了一个成员函数指针:
class ClassA
{
public:
void FuncA(void);
...
}
void GlobalFunc(void)
{
typedef void(ClassA::*MemberFnPtr)(void);
MemberFnPtr fnPtrA = &ClassA::FuncA;
...
}
这样的模式也很好地工作(因为运营商:比运营商&有更高的优先级)
typedef void(ClassA::*MemberFnPtr)(void);
MemberFnPtr fnPtrA = &(ClassA::FuncA);
...
然而,当我在成员函数中使用后一种模式时,会出现一些奇怪的error C2276:"&"
;
我在std::bind
&std::function
,我认为这对我来说会更好。然而,我真的想知道当我在成员函数中使用后一种模式时发生了什么,有人能帮忙吗?
您不应该在成员函数的名称周围使用括号:
MemberFnPtr fnPtrA = &(ClassA::FuncA); // not good
MemberFnPtr fnPtrA = &ClassA::FuncA; // good
C++标准在第5.3.1节:中明确提到了这一点
注意:即表达式&(限定id),其中限定id包含在括号,不构成"指向成员的指针"类型的表达式。
你必须使用这种形式(正如anatolig所说):
MemberFnPtr fnPtrA = &ClassA::FuncA;
要调用fnPtrA
,您必须创建一个对象并调用它,如下所示:
ClassA a;
(a.*fnPtrA)();
这是一个奇怪的语法,因为fnPtrA
不是ClassA
的成员。
相关文章:
- 如何使用指针传递给函数的数组中对象的函数成员
- c++构造函数成员初始化:传递参数
- 创建 std::函数,它返回具有函数成员值的变量.分段错误
- 如何在C++通过公共函数访问私有函数成员?
- 解释了构造函数成员初始化列表
- 调用std::函数成员时内存损坏
- 是否可以为模板类的模板函数成员设置别名?
- 捕获 lambda 函数C++成员变量
- 构造函数成员初始值设定项跨成员列出,安全吗?
- 获取与在模板参数中传递的函数成员类型相同的类
- 如何从公共函数成员访问地图私有成员
- C 构造函数成员分配优化
- 使用命名空间进行函数成员定义
- 函数成员作为 CUDA 内核的参数
- 模板基类函数成员的别名
- 函数成员中用于void和继承的enable_if
- 头文件中是否定义了一个很长的Class函数成员
- 类内/构造函数成员初始化
- 使用指向部分专用函数成员的指针自动填充向量
- 指向函数成员的指针