我正在使用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 ++代码中被两次声明(在两个不同的文件中)并具有不同的签名。 最佳答案
如注释中所述,将对comparePairs()
的函数调用包装到lambda函数中可以解决此问题。
见https://github.com/facebookresearch/fastText/pull/936/commits/cda295f1b5851df0a26a6ac2ab04230fb864a89d