首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Java OutputFormat发出Scala元组

使用Java OutputFormat发出Scala元组
EN

Stack Overflow用户
提问于 2016-09-09 12:45:11
回答 1查看 435关注 0票数 1

我正在尝试为ArangoDB编写一个自定义的ArangoDB。我使用CassandraOutputFormat.java作为灵感,交换了相关的驱动程序和调用等等。我用Java编写了这篇文章,因为我找不到OutputFormat的Scala示例。因此,该类的定义如下:

代码语言:javascript
复制
public class ArangoOutputFormat<OUT extends Tuple> extends RichOutputFormat<OUT>

现在,我想要写入ArangoDB的Flink程序是用Scala编写的。dataset testDataSet[Tuple2[Long, Long]]。写到ArangoDB的调用如下所示:

代码语言:javascript
复制
test.output(
  new ArangoOutputFormat[(Long, Long)]()
);

但是,在编译时,我会得到以下错误:

错误:(47,11)类型参数(长、长)不符合类ArangoOutputFormat的类型参数界限<:org.apache.flink.api.java.tuple.Tuple新ArangoOutputFormat(Long,Long)

在使用Scala和Java类时,我通常对类型系统感到有点困惑,有人能解释一下这里发生了什么吗?

谢谢你,罗伯

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-09 12:58:09

ArangoOutputFormat被输入到Flink的Java (org.apache.flink.api.java.tuple.Tuple),而您的Scala程序则使用Scala的元组。Flink的Java元组与Scala的元组不兼容。您需要显式地创建Java元组,例如在接收器之前的Mapper中。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39411928

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档