将C ++引用包装到C API中

我有一个头文件,应该是一个组合的C ++和C API。 C部分被包装成extern "C" ,但声明本身看起来与C不同; 例如:

 foo::Bar& Foo_Baz_GetBarOfQux(void *_self, const foo::Qux &qux); 

有没有办法从普通C实际使用它? 我显然不能使用这个标题,但也许我可以以某种方式重新声明它:

 /* type? */ Foo_Baz_GetBarOfQux(void*, const /* type? */); 

令我困惑的是如何声明这些引用的类型(如果可能的话)。

PS我知道我可以在此基础上编写自己的C包装器:我将类声明为不透明结构:

 typedef struct foo_bar foo_bar_t; typedef struct foo_baz foo_baz_t; typedef struct foo_qux foo_qux_t; 

然后编写一个包含上述函数的类C函数:

 extern "C" foo_bar_t* foo_baz_get_bar_of_qux( foo_baz_t* baz, foo_qux_t* qux) { return (foo_bar_t*) Foo_Baz_GetBarOfQux(baz, *(foo::Qux*)qux); } 

但我想知道我是否可以直接使用原始的Foo_Baz_GetBarOfQux()

不,你不能直接使用Foo_Baz_GetBar() ,在c++对成员函数的调用涉及隐式传递一个在c代码中不存在的this指针。

通常,使用不透明结构会更好。

在代码的“C”界面中,不要试图在不透明结构中撬动,只是尽职尽责地传递指针。

在“C ++”部分中,您应该定义结构并实际填充它们(我会避免盲目的类型转换)。

当然,“C ++”部分不应该在“C”标题中公开,以免它混淆C编译器。