如何将std::函数的目标与成员函数的地址进行比较?

2022-04-14 00:00:00 bind c++

我正在尝试弄清楚如何将函数对象的目标(即成员函数)与实际的成员函数进行比较。 当然,它们应该匹配。

但我没有使它们匹配,并且我不明白将成员函数声明为函数对象的类型的语法。

以下是一些代码:

#include <cstdlib>
#include <iostream>
#include <functional>
using namespace std;


class Object {
public:
    void method () {}
};


int main(int argc, char** argv) {

    Object* obj = new Object();
    function<?????> wrapper = bind(&Object::method, obj);
    if (wrapper.target<?????>() == &Object::method) {
        cout << "match" << "
";
    } else {
        cout << "no match" << "
";
    }   
    delete(obj);

    return 0;
}

我尝试放置不同的东西,而不是?,但没有成功。

那么,我应该写什么来代替问号,或者此代码是否存在其他问题?


解决方案

function<?????> wrapper = bind(&Object::method, obj);

绑定表达式返回一个不需要参数的可调用对象,并返回void,因此逻辑调用签名为void(),因此您需要std::function<void()>

if (wrapper.target<?????>() == &Object::method) {

这不起作用,因为function不包含指向成员函数的指针,它包含bind表达式的结果,该表达式包装指向成员函数的指针。

绑定表达式返回的类型(因此是function目标的类型)是一些内部实现细节,如_Binder<void, _Mem_fn<Object, void()>, Object*>,您不能直接引用。

您可以这样做:

auto b = bind(&Object::method, obj);
function<void()> wrapper = b;
if (wrapper.target<decltype(b)>() != nullptr) {

但这并不能告诉您任何有用的信息。

相关文章