java返回类型自动_java-Apache Flink:由于类型擦除,无法自动确定函数的返回类型...

我在Java中用Flink编写了一个简单的程序,它以文件或文本作为输入,然后使用flatMap函数打印所有单词。

这是我的代码:

final ParameterTool params = ParameterTool.fromArgs(args);

StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();

env.getConfig().setGlobalJobParameters(params);

// show user defined parameters in the apache flink dashboard

DataStream<String> dataStream;

if(params.has("input"))

{

System.out.println("Executing Words example with file input");

dataStream = env.readTextFile(params.get("input"));

}else if (params.has("host") && params.has("port"))

{

System.out.println("Executing Words example with socket stream");

dataStream = env.socketTextStream(params.get("host"), Integer.parseInt(params.get("port")));

}

else {

System.exit(1);

return;

}

DataStream<String> wordDataStream = dataStream.flatMap(

(String sentence, Collector<String> out) -> {

for(String word: sentence.split(" "))

out.collect(word);

});

wordDataStream.print();

env.execute("Word Split");

但是当我用这个命令运行它时:

bin/flink run -c Words FlinkExample-0.0.1-SNAPSHOT.jar --host localhost --port 9999

我得到以下错误:

程序失败,出现以下异常:

函数main的返回类型(单词.java:32)由于类型删除,无法自动确定“”。可以通过对 transformation调用的结果使用returns(…)方法,或通过让函数实现“ResultTypeQueryable”接口来提供类型信息提示。

(第32行表示第二个数据流的声明)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值