0

我正在使用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++ 代码中(在两个不同的文件中)声明了两次具有不同签名的函数。

4

1 回答 1

0

如评论中所述,将函数调用包装comparePairs()到 lambda 函数中可以解决此问题。

https://github.com/facebookresearch/fastText/pull/936/commits/cda295f1b5851df0a26a6ac2ab04230fb864a89d

于 2019-10-25T12:38:02.057 回答