我正在使用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

10-08 08:34