gpt4 book ai didi

java - TStream 中的元组到底是什么?

转载 作者:行者123 更新时间:2023-11-30 07:46:43 26 4
gpt4 key购买 nike

这是从 Apache Edgent Documentation 中获取的代码

我不明白元组到底是什么。代码如下:

public static void main(String[] args) throws Exception {
TempSensor sensor = new TempSensor();
DirectProvider dp = new DirectProvider();
Topology topology = dp.newTopology();

TStream<Double> tempReadings = topology.poll(sensor, 1, TimeUnit.MILLISECONDS);
TStream<Double> simpleFiltered = tempReadings.filter(tuple ->
!optimalTempRangeRef.get().contains(tuple));
simpleFiltered.sink(tuple -> System.out.println("Temperature is out of range! "
+ "It is " + tuple + "\u00b0F!"));

tempReadings.print();

dp.submit(topology);
}

我得到的错误是tuple cannot be resolved to a variable。我得到的错误到底是什么?谢谢。

最佳答案

TStream<T> interface旨在模拟数据流,通常是传感器读数。 T在这种情况下是用于存储单个读数的类型,但“读数”实际上可以表示多个数字(例如温度、湿度和风速)连接在一起形成一个复合类型,这里通常称为“元组”值(value)观。

但是,查看您的示例的上下文,我们正在处理一系列简单的温度读数,所以这里 T对应单号类型Double .因此,选择“元组”作为变量名有点令人困惑(从数学上讲,它是一个 1 元组,但在这种情况下,它仅表示“数字”)。

在您的代码中,filter()方法需要一个 predicate , 这是

tuple -> !optimalTempRangeRef.get().contains(tuple)

optimalTempRangeRef.get()返回 Range(Double) ,所以谓词是说“我们的温度值是否超出我们的最佳范围?”

来自 Range 的文档:

contains() is used to check for containment: e.g.

Ranges.closed(2,4).contains(2); // returns true
Ranges.open(2,4).contains(2); // returns false
Ranges.atLeast(2).contains(2); // returns true
Ranges.greaterThan(2).contains(2); // returns false
Ranges.atMost(2).contains(2); // returns true
Ranges.lessThan(2).contains(2); // returns false

编辑:

看起来您的 IDE 在使用 Java 8 lambda 语法时遇到了问题,因此您可以使用匿名内部类重写代码,如下所示:

import org.apache.edgent.function.Predicate;
import org.apache.edgent.function.Consumer;


public static void main( String[] args ) throws Exception
{
TempSensor sensor = new TempSensor();
DirectProvider dp = new DirectProvider();
Topology topology = dp.newTopology();

TStream<Double> tempReadings = topology.poll( sensor, 1, TimeUnit.MILLISECONDS );
TStream<Double> filteredStream = tempReadings.filter( new Predicate<Double>()
{
public boolean test( Double reading )
{
return !optimalTempRangeRef.get().contains( reading );
}
} );

filteredStream.sink( new Consumer<Double>()
{
public void accept( Double reading )
{
System.out.println( "Temperature is out of range! "
+ "It is " + reading + "\u00b0F!" )
}
} );

tempReadings.print();

dp.submit( topology );
}

关于java - TStream 中的元组到底是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50525962/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com