我正在使用JavaCPP为 C++ 项目实现 Java 包装器。我已经为所有自定义类型定义了映射,但是我正在努力调用将std::sort_heap()
函数作为参数的函数。
这是 C++ 代码中的函数调用:
std::sort_heap(heap.begin(), heap.end(), comparePairs);
comparePairs
在此文件中声明如下:
bool comparePairs(
const std::pair<real, int32_t>& l,
const std::pair<real, int32_t>& r) {
return l.first > r.first;
}
当我尝试使用 JavaCPP(使用JavaCPP Maven 插件)运行它时,我收到此错误:
error: no matching function for call to ‘pop_heap(std::vector<std::pair<float, int> >::iterator, std::vector<std::pair<float, int> >::iterator, <unresolved overloaded function type>)’
std::pop_heap(heap.begin(), heap.end(), comparePairs);
^
更新:问题似乎是由于compairePairs()
另一个文件中声明了另一个签名函数略有不同的事实。考虑到每个compairePairs()
函数只在同一个文件中调用,C++ 编译器可以很好地消除它们的歧义。然而,JavaCPP 似乎以某种方式在这种歧义上失败了。
这是其他类型映射的声明方式:
import org.bytedeco.javacpp.tools.Info;
import org.bytedeco.javacpp.tools.InfoMap;
import org.bytedeco.javacpp.tools.InfoMapper;
[...]
@Properties(value = @Platform(include = {[...]}), target = "[...]")
public class Wrapper implements InfoMapper {
public void map(InfoMap infoMap) {
infoMap.put(new Info("std::vector<std::string>").pointerTypes("StringVector").define())
// more put calls here
;
}
}
因此问题是:为什么 JavaCPP 无法消除重载函数的歧义,我该如何解决?
注意:C++ 代码是第三方项目,因此不能更改 C++ 代码。
更新:问题似乎是由于compairPairs()
在 C++ 代码中(在两个不同的文件中)声明了两次具有不同签名的函数。