首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flink实战(三) - 编程范式及核心概念

首先,它们是不可变的,这意味着一旦创建它们,就无法添加或删除元素。 也不能简单地检查里面的元素。...因此,无需将数据集类型物理打包到键和值中。 键是“虚拟的”:它们被定义为实际数据上的函数,以指导分组操作符。 注意:在下面的讨论中,将使用DataStream API和keyBy。...以下示例显示了一个键选择器函数,它只返回一个对象的字段: Java Scala 6 指定转换函数 大多数转换都需要用户自定义的函数。...这些用于参数化函数(请参阅将参数传递给函数),创建和完成本地状态,访问广播变量以及访问运行时信息(如累加器和计数器) 7 支持的数据类型 Flink对DataSet或DataStream中可以包含的元素类型设置了一些限制...7.4 General Class Types Flink支持大多数Java和Scala类(API和自定义)。 限制适用于包含无法序列化的字段的类,如文件指针,I / O流或其他本机资源。

1.5K20

Flink实战(三) - 编程范式及核心概念

首先,它们是不可变的,这意味着一旦创建它们,就无法添加或删除元素。 也不能简单地检查里面的元素。...而是创建每个操作并将其添加到程序的计划中。 当执行环境上的execute()调用显式触发执行时,实际执行操作。...因此,无需将数据集类型物理打包到键和值中。 键是“虚拟的”:它们被定义为实际数据上的函数,以指导分组操作符。 注意:在下面的讨论中,将使用DataStream API和keyBy。...这些用于参数化函数(请参阅将参数传递给函数),创建和完成本地状态,访问广播变量以及访问运行时信息(如累加器和计数器) 7 支持的数据类型 Flink对DataSet或DataStream中可以包含的元素类型设置了一些限制...7.4 General Class Types Flink支持大多数Java和Scala类(API和自定义)。 限制适用于包含无法序列化的字段的类,如文件指针,I / O流或其他本机资源。

1.4K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Scala-8.面向对象-构造函数

    辅助构造函数必须用this为名创建 每个辅助构造函数必须从调用之前定义的构造函数开始 一个构造函数通过this调用另一个不同的构造函数 case class里添加的辅助构造函数不是构造函数,是类的伴生对象中的...timeout: Int = 10000) 覆盖默认的访问和修改方法:常见方法是在参数名前添加一个_name,然后根据Scala的约定声明getter和setter方法 阻止生成getter方法和setter...private[this]修饰意味着只有包含改字段的对象可以访问,字段甚至无法被相同类型的其他实例访问。...* 调用父类的构造函数:在Scala定义子类时,可以在子类定义extends时控制被其主构造函数调用的超类构造函数。...* 辅助构造函数的第一行必须调用当前类的另一个构造函数,好久无法调用超类的构造函数

    98540

    JVM 上数据处理语言的竞争:Kotlin, Scala 和 SPL

    SPL内置专业的数据处理函数,提供了大量时间复杂度更低的基本运算,通常不需要外部Java类库,特殊情况可在自定义函数中调用。 IDE和调试   三者都有图形化IDE和完整的调试功能。...也可以用OpenCSV等类库读取,数据类型虽然不用在代码中解析,但要在配置文件中定义,实现过程不见得简单。...Scala比Kotlin专业,不仅内置了多种数据源接口,而且提供了跨源计算的函数。...但Scala缺乏有序计算能力,相关的功能通常要添加序号列再处理,导致整体代码冗长。...SPL支持有序计算,可以直接按位置分组,按位置取字段,从集合中的集合取字段,虽然实现思路和Scala类似,但代码简短得多。

    2.5K100

    Scala简介:面向对象和函数式编程的组合

    或者它们允许静态字段和方法不隶属于任何对象。这些对纯理想化面向对象编程的背叛最初看起来完全无害,但它们有一个讨厌的趋势,把事情复杂化并限制了可伸缩性。...你可以把函数当作参数传递给其他函数,当作结果从函数中返回或保存在变量里。你也可以在函数里定义其他函数,就好像在函数里定义整数一样。...还可以定义匿名函数,就好像你或许会写像42这样的整数文本那样方便地用函数文本抛洒在代码中。 把函数作为第一类值为操作符上的抽象和创建新控制结构提供了便利的方法。...举例来说,C和C++的函数指针就不能拥有与非函数指针在语言中同等的地位:函数指针仅能指向全局函数,它们不允许你定义指向环境中什么值的第一类嵌套函数,也不能定义匿名函数文本。...因此单看字串来说,Java是函数式语言,而Ruby不是。不可变数据结构是函数式语言的一块基石。Scala库在Java API之上定义了更多的不可变数据类型。

    1.2K60

    Python和Scala的类和对象(一)

    前面的文章我们更多的是关注于函数,现在开始进入面向对象的世界了。函数是一种对过程的抽象,它提供了单一的入口和出口,封装了一系列的逻辑处理,而类和对象更像是对物体的抽象,它可以继承和组合。...这个定义的关键在于它无法被实例化,抽象基类可以拥有那些无需实现的方法。抽象基类很强大,并且广泛运用在类库和框架上,但是也很容易过度设计。...通过属性化方法实现某些需要特定逻辑的字段,并且可以封装字段,不让字段被轻易修改。Scala和Python都提供了这种机制去让你把没有参数传入的方法当成属性进行调用。...继续在上面的Book类上面添加一个方法pages,它可以获得打开的书的页数。...这里的Scala的方法定义中没有使用(),而Python使用了property描述符,这样的话,我们可以像调用字段一样调用方法。

    42910

    Spark2.x学习笔记:2、Scala简单例子

    = 1.4142135623730951 scala> 备注:在Scala中,_字符是“通配符”,类似Java中的* (2)自定义函数 函数的定义用 def 开始。...普通函数的定义语法如下: def funName(para1:Type1,para2:Type2):Type = { do some things } 高阶函数其实就是普通函数中的参数进一步推广了,高阶函数的参数可以是一个函数...) (3,c) scala> 总结: scala提供了许多用于添加和移除元素的操作符,总结如下。...Scala对每个字段都提供了getter和setter方法,在生成面向JVM的类时,每个字段生成一个私有字段以及对应的getter和setter方法,这两个方法是public,在需要时可以重新定义getter...这是因为Scala在伴生对象中定义了apply方法,该方法返回的是伴生类的对象。

    3.1K80

    值得收藏:一份非常完整的 MySQL 规范(一)

    所有表和字段都需要添加注释使用 comment 从句添加表和列的备注 从一开始就进行数据字典的维护。...,也会消耗更多的 IO) 更有效的利用缓存,避免读入无用的冷数据 经常一起使用的列放到一个表中(避免更多的关联操作) 7.禁止在表中建立预留字段预留字段的命名很难做到见名识义 预留字段无法确认存储的数据类型...,所以无法选择合适的类型 对预留字段类型的修改,会对表进行锁定 8.禁止在数据库中存储图片,文件等大的二进制数据通常文件很大,会短时间内造成数据量快速增长,数据库进行数据库读取时,通常会进行大量的随机...尽可能把所有列定义为 NOT NULL 原因: 索引 NULL 列需要额外的空间来保存,所以要占用更多的空间。 进行比较和计算时要对 NULL 值做特别的处理。 5....经常会有人用字符串存储日期型的数据(不正确的做法): 缺点 1:无法用日期函数进行计算和比较。 缺点 2:用字符串存储日期要占用更多的空间。 6.

    72910

    Flink实战(六) - Table API & SQL编程

    而且Flink提供不同级别的抽象来开发流/批处理应用程序 最低级抽象只提供有状态流。它通过Process Function嵌入到DataStream API中。...这些流畅的API提供了用于数据处理的通用构建块,例如各种形式的用户指定的转换,连接,聚合,窗口,状态等。在这些API中处理的数据类型在相应的编程语言中表示为类。...虽然 Table API可以通过各种类型的用户定义函数进行扩展,但它的表现力不如Core API,但使用更简洁(编写的代码更少)。...以下依赖项与大多数项目相关: flink-table-common 通过自定义函数,格式等扩展表生态系统的通用模块。..._2.11 1.8.0 2.4 扩展依赖 如果要实现与Kafka或一组用户定义函数交互的自定义格式,以下依赖关系就足够了

    1.3K20

    Scala学习笔记(二)

    Scala是什么,能做什么? Scala是一门多范式的编程语言,一种类似java的编程语言 ,设计初衷是实现可伸缩的语言、并集成面向对象编程和函数式编程的各种特性。...Scala的基础语法 我整理了自己学习过程中感到有必要记录的东西,以防忘记 1. val 与 var Scala 有两种定义变量的方式:val和var。 当val定义好变量之后,无法更改变量的值。...类中getter/setter 方法 在Java中,通常将字段声明为私有的,然后添加公有的getter和setter方法来提供访问字段的接口。...然而,Scala 对每个字段都提供了getter和setter方法。...val声明的字段无法实现setter.png 总结 Scala 的语法跟 Kotlin 颇有相似之处,我是先学习了 Kotlin 再来学 Scala 的,所以对于 Scala 的语法毫无违和感。

    58730

    Scala代码编写中常见的十大陷阱

    很多Java开发者在学习Scala语言的时候,往往觉得Scala的语法和用法有些过于复杂,充满语法糖,太“甜”了。在使用Scala编写代码时,由于语法和编写习惯的不同,很多开发者会犯相同或相似的错误。...用法错误 把var和val认为是字段(fields): Scala强制使用统一访问准则(Uniform Access Principle),这使得我们无法直接引用一个字段。...所有对任意字段的访问只能通过getters和setters。val和var事实上只是定义一个字段,getter作为val字段,对于var则定义一个setter。...Java程序员通常认为var和val是字段,而当发现在他们的方法中它们共享相同的命名空间时,常常觉得惊讶。因此,不能重复使用它们的名字。...共享命名空间的是自动定义的getter和setter而不是字段本身。通常程序员们会试图寻找一种访问字段的方法,从而可以绕过限制——但这只是徒劳,统一访问准则是无法违背的。

    1.1K50

    2021年大数据常用语言Scala(二十六):函数式编程 分组 groupBy

    ---- 分组  groupBy 我们如果要将数据按照分组来进行统计分析,就需要使用到分组方法 等同于SQL中的 group by的概念, 就是给数据按照指定的列进行分组用。...定义 groupBy表示按照函数将列表分成不同的组 方法签名 def groupBy[K](f: (A) ⇒ K): Map[K, List[A]] 方法解析 groupBy方法 API 说明 泛型 [...K] 分组字段的类型 参数 f: (A) ⇒ K 传入一个函数对象接收集合元素类型的参数返回一个K类型的key,这个key会用来进行分组,相同的key放在一组中 返回值 Map[...K, List[A]] 返回一个映射,K为分组字段,List为这个分组字段对应的一组数据 groupBy执行过程分析 示例 有一个列表,包含了学生的姓名和性别: "张三", "男" "李四", ..."女" "王五", "男" 请按照性别进行分组,统计不同性别的学生人数 步骤 定义一个元组列表来保存学生姓名和性别 按照性别进行分组 将分组后的Map转换为列表:List(("男" -> 2), ("

    94230

    3小时Java入门

    通过enum定义的枚举类,其实也是一个class,只不过它有以下几个特点: 定义的enum类型总是继承自java.lang.Enum,且无法被继承; 只能定义出enum的实例,而无法通过new操作符创建...因为枚举类也是class, 所以我们可以定义private的构造方法,并且,给每个枚举常量添加字段。 ? 十四,选择结构 Java的选择结构主要有 if 语句和 switch语句。...如果一个抽象类没有字段,所有方法全部都是抽象方法,那么该抽象类就可以被改写成接口(interface)。 Java 中的 interface具有和 Scala中的 trait相似的功能。...Java编程风格统一为面向对象,Scala支持面向对象和函数式编程多种风格 Java中的多分支用switch, Scala使用match模式匹配实现多分支。...5,C++ 中可以在类的外部可以定义函数,而Java不允许在类和接口外面直接定义方法。

    2.7K30

    Spark基础-scala学习(三、Trait)

    面向对象编程之Trait trait基础知识 将trait作为接口使用 在trait中定义具体方法 在trait中定义具体字段 在trait中定义抽象字段 trait高级知识 为实例对象混入trait...with parameter Person[name=Tom] 在trait中定义具体字段 scala中trait可以定义具体field,此时继承trait的类就可以自动获得trait中定义的field...但是这种获取field的方式与继承class是不同的:如果是继承class获得的field,实际是定义在父类中的;而继承trait获取的field,就直接被添加到类中 scala> :paste //...scala> s.sayHello Hi,I'm Tom,I have 2 eyes 在Trait中定义抽象字段 scala中的Trait可以定义抽象field,而trait中的具体方法则可以基于抽象...在scala中,trait是没有接受参数的构造函数的,这是trait与clas的唯一区别,但是如果需求就是要trait能够对field进行初始化,我们可以使用scala中非常特殊的一种高级特性--提前定义

    48720

    scala快速入门系列【特质】

    ---- 特质(trait) scala中没有Java中的接口(interface),替代的概念是——特质。...定义 特质是scala中代码复用的基础单元 它可以将方法和字段定义封装起来,然后添加到类中 与类继承不一样的是,类继承要求每个类都只能继承一个超类,而一个类可以添加任意数量的特质。...---- trait中定义具体的字段和抽象的字段 定义 在trait中可以定义具体字段和抽象字段 继承trait的子类自动拥有trait中定义的字段 字段直接被添加到子类中 示例 通过trait...在scala中,trait是可以定义抽象方法,也可以定义具体方法的。 trait中定义了一个抽象方法 trait中定义了其他的几个具体方法,会调用抽象方法。...对象混入trait scala中可以将trait混入到对象中,就是将trait中定义的方法,字段添加到一个对象中。 定义 ?

    49520

    大数据分析工程师面试集锦2-Scala

    函数相关 函数在Scala中是一等公民,对这一块的考察应该是最多的,函数如何定义?什么是方法?偏函数、闭包、科里化等概念如何理解?高阶函数有哪些?什么是尾递归?什么是部分应用函数?...有区别的,不加关键字的话,这个参数只能用于类的实例化,一旦实例化后这些参数就不可以使用了,如果加关键字的话这些参数就成为类中的一个字段。 30 case class(样本类)是什么?...它具有以下特性: (1)构造对象时,不需要new; (2)类中的参数默认添加val关键字,即参数不能修改,如果需要的话也可以使用var; (3)默认实现了toString,equals,hashcode...抽象类是在普通类的基础上增加了abstract关键字,无法对其进行实例化,它是用来被子类继承的,抽象类中可以只定义字段和方法,具体的值和实现在其子类中实现,子类也可以进行重写。...所谓隐式参数,指的是在函数或者方法中,定义使用implicit修饰的参数。

    2.1K20

    大数据之脚踏实地学19--Scala中类的使用

    前言 在前面的一系列Scala编程基础中,我们介绍了Scala的基本语法、控制流、自定义函数、数据结构等内容。从本期开始将会陆续介绍Scala中面向对象的编程内容,包括类、对象、继承以及特质等。...案例1 如下代码中构造了一个Ball类,其中包含一个成员字段(或成员变量)PI,和三个成员方法(或成员函数),这三个方法的功能分别是计算圆的周长、面积和球的体积。...案例2 在下面的代码中我们构造了一个Income类,该类包含了两个参数,分别是字符型的name和双精度浮点型的income。...类中没有成员字段,只有一个计算税后收入的方法taxIncome,读者可以将如下代码复制到txt文件中,并给文件命名为ClassDemo02.scala。...需要说明的是,如果类参数使用了val或var这样的关键词,则表明对应的参数便成了类的成员字段,可以通过".字段名"的方法调用对应的值;如果没有使用val或var关键词,并且类体中也没有使用到参数,此时无法通过

    44820

    Flink DataStream 类型系统 TypeInformation

    1.3.2 Scala Case Class 与 Tuple 类型 Flink 支持任意的 Scala Case Class 以及 Scala tuples 类型,支持的字段数量上限为 22,支持通过字段名称和位置索引获取指标...需要注意的是,如果根据名称获取字段,可以使用 Tuple 中的默认字段名称: // 通过 scala Tuple 创建具有两个元素的数据集 val tupleStream: DataStream[Tuple2...每个字段的类型都可以不一样并且每个字段都可以为空。由于无法自动推断行字段的类型,因此在生成 Row 时都需要提供类型信息。...但是有时无法提取必要的信息,例如定义函数时如果使用到了泛型,JVM 就会出现类型擦除的问题,使得 Flink 并不能很容易地获取到数据集中的数据类型信息。...对于函数的返回类型取决于输入类型的情况时,会包含一些简单的类型推断。但如果无法重构所有的泛型类型信息时,需要借助于类型提示来告诉系统函数中传入的参数类型信息和输出参数信息。

    4.4K51
    领券