0

我在一个普通的 C 静态库中有这段代码:

extern "C" {
    typedef void (__cdecl* VisitChildren)(Option*);
    void __cdecl DoVisitChildren(Children* List, VisitChildren Visitor);
}

我正在尝试使用 lambda 从一些 C++ 代码(单元测试)中使用它。

...
DoVisitChildren(children, [&] (Option* option) {
...
});

我收到编译器错误C2664 ... cannot convert parameter 2 from 'unittests::UnitTest1::TestBuild::<lambda_b286d160b9bab3e09ab93cd59fc49f0b>' to 'VisitChildren'

如果我删除捕获'&',它会编译并工作,但我需要捕获一些零碎的东西。

这可能吗?

4

1 回答 1

2

由 lambda 表达式创建的闭包可以隐式转换为函数指针,但前提是它不捕获任何变量。此外,它将被转换为指向extern "C++"函数的指针,而不是extern "C"函数,从技术上讲,它们是不兼容的类型。

所以不,你不能这样做。

一个 hacky 解决方法是将您的实际闭包存储在一个全局变量中并传递一个调用它的回调。这仅在您的程序是单线程的并且DoVisitChildren调用不存储回调以供以后使用时才有效。

std::function<void(Option*)> callback;
extern "C" void __cdecl invoke_callback(Option* o) { callback(o); }

// ...

callback = [&] (Option* option) { /* ... */ };
DoVisitChildren(children, invoke_callback);
于 2013-08-28T14:14:03.127 回答