我正在使用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 plugin)运行此命令时,出现此错误:
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 ++代码中两次声明(在两个不同的文件中)具有不同的签名。
答案 0 :(得分:0)
如评论中所述,将对comparePairs()
的函数调用包装到lambda函数中即可解决问题。