我可以在c#中使用类似c++的委托中的方法指针吗
Can I use method pointers in c++ alike delegates in c#?
我想让class'(为了方便起见,我们称它为X)方法能够使用指向自己方法的指针,在这种情况下,我可以提取只因调用的方法不同而不同的代码。
例如,具有几个块,如:
a();
b();
c();
MehtodCall(someResultOfabc);
d();
e();
我想提取一个只使用作为指针传递的不同方法的方法:
所以我想要类似的东西:
void X::ExtractedMethod( void(X::*MethodCallPointer)(TypeOfABCResult) ){
a();
b();
c();
this->*MethodCallPointer(someResultOfabc);
d();
e();
}
并以这样的方式使用这个功能:
void X::DoSomethingA(){
ExtractedMethod(&X::ADoer);
}
void X::DoSomethingB(){
ExtractedMethod(&X::BDoer);
}
和操作系统…
不幸的是,我被困在这里,因为我得到了一个编译错误,方法指针没有计算到一个需要一个参数的方法调用。
我开始怀疑,原因是否是X在这个声明中是一个不完整的类型?
如果有人能帮助我,告诉我怎么做,或者为什么这不可能,我会很高兴。
我真的,真的不想得到一些变通办法,比如在签名和lambda中使用std::函数,或者使用指向静态方法的指针,该方法使用X*并调用我需要的特定方法,也不制作switch语句和标志,也不使用switch语句来代替该switch语句使用接口,实现策略patern并使用策略的静态实例作为参数;)这些并不是这种情况下的全部解决方法,但我仍然不想阅读其他解决方法。我唯一感兴趣的是"这是可能的,以及如何做到"。
@Robert是对的,在C++中使用委托的惯用方法是将std::function
与std::bind
一起使用。
然而,如果您坚持使用指向方法的指针作为适当委托的变通方法,那么正确的语法是:
void X::ExtractedMethod( void(X::*MethodCallPointer)(TypeOfABCResult) ){
(this->*MethodCallPointer)(someResultOfabc);
// ^ ^
// note the parentheses, they are required
在C++中,您可以使用boost-bind来绑定函数调用:
void X::DoSomethingA(){
ExtractedMethod( boost::bind(&X::ADoer, pInstance) );
}
如果X::ADoer不是类X的静态成员,则需要pInstance。
对于函数类型,您可以使用std::function(最新的C++)或boost::function。
typedef std::function< void(TypeOfABCResult) > MyDelegateType;
void X::ExtractedMethod( MyDelegateType delegate ) { ... }
这不是一个变通办法。这就是你在C++中的工作方式,它的工作方式与在C#中使用委托的工作方式非常相似。
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- 通过方法访问结构
- 最小硬币更换问题(自上而下方法)
- C++为构建时间获取QDateTime的可靠方法
- 在C#中处理C++指针而不使用unsafe的最佳方法
- 处理多个异常集合的C++方法
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 有什么方法可以遍历结构吗
- 当类在C++中定义时,有什么方法可以"register"类吗?
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- 使用std::函数映射对象方法
- 有符号的int和int-有没有一种方法可以在C++中区分它们
- C++从另一个类访问公共静态向量的正确方法是什么
- C++优先级队列,按对象的唯一指针的特定方法升序排列
- 没有为自己的结构调用列表推回方法
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 在类定义之后定义一个私有方法
- 枚举环境变量的惯用C++14/C++17方法
- 初始化具有非默认构造函数的std::数组项的更好方法