如何将 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
.
我正在尝试在 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
.