一.简介
为了在Scala和Java API之间保持相当程度的一致性,用于批处理和流传输的标准API省略了一些允许在Scala中进行高水平表达的功能。
如果想享受完整的Scala体验,则可以选择加入通过隐式转换来增强Scala API的扩展。
要使用所有可用的扩展,只需导入相应的扩展组件即可:
1.DataSet API
import org.apache.flink.api.scala.extensions._
2.DataStream API
import org.apache.flink.streaming.api.scala.extensions._
另外,也可以根据需要导入单个扩展。
二.扩展模式匹配
通常,DataSet和DataStream API都不接受匿名模式匹配函数来匹配元组,案例类或集合,如下所示:
val data: DataSet[(Int, String, Double)] = // [...]
data.map {
case (id, name, temperature) => // [...]
// The previous line causes the following compilation error:
// "The argument types of an anonymous function must be fully known. (SLS 8.5)"
}
此扩展在DataSet和DataStream Scala API中引入了新方法,这些新方法在扩展API中具有一对一的对应关系。这些扩展方法支持匿名模式匹配功能。
1.DataSet API
DataSet要专门使用此扩展,可以添加以下内容:
import org.apache.flink.api.scala.extensions.acceptPartialFunctions
2.DataStream API
DataStream要专门使用此扩展,可以添加以下内容:
import org