如何将 std::function 从 Objective-C++ 传递给 C++ 方法

How to pass a std::function from Objective-C++ to C++ method

我正在尝试在 Objective-C++ 方法中创建一个 std::function,并将其传递给 C++ 方法。

但是我遇到了错误的访问异常。我试过使用 Objective-C 块和 lambda:

使用块:

std::function<void(void)> callback = ^{
    [self doSomething];
};

callback(); // <-- this works

self.myCppObject-> setButtonCallback(callback);

使用 lambda:

std::function<void()> callback = [self]() {
    [self doSomething];
};

callback(); // <-- this works

self.myCppObject->setButtonCallback(callback);

在我的 C++ 中 class:

void MyCppClass::setButtonCallback (std::function<void()> callback)
{
    buttonCallback = std::move (callback); // <-- crash here
}

我还尝试将 callback 存储在 Objective-C++ class 中作为 属性:

@property (nonatomic, assign) std::function<void()> callback;

这里抛出异常:(第1717行来自<functional>

template<class _Rp, class ..._ArgTypes>
function<_Rp(_ArgTypes...)>&
function<_Rp(_ArgTypes...)>::operator=(function&& __f) _NOEXCEPT
{
    if (__f_ == (__base*)&__buf_) // <-- EXC_BAD_ACCESS here
        __f_->destroy();
    else if (__f_)
        __f_->destroy_deallocate();
    __f_ = 0;

    ...

来自C++方法中的回调赋值。我尝试同时使用 std::move 并通过 =.

进行复制

更新

问题原来是 myCppObject 没有被初始化,因为它是 class 的一个子 class ,它在它的构造函数中初始化了它,但是我调用了基 [super init] 而不是我需要的 [super initWith...] 。感谢@Roman 提供的线索。

我尝试 运行 你的代码,但只有当 属性 self.myCppObject 之前没有初始化时我才会收到同样的错误。尝试替换

self.myCppObject-> setButtonCallback(callback);

self.myCppObject = new MyCppClass();
self.myCppObject-> setButtonCallback(callback);

或检查您是否正确初始化 属性 self.myCppObject.