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

追随 KotlinScala,看 Java 12-15 现代语言特性

我们看一个不严谨示例:判断一个对象对应哪种 JSON 类型,使用传统 switch 语句实现如下: switch (obj.getClass().getSimpleName()) { case..."; }; System.out.println(jsonType); switch 表达式中箭头右侧不仅可以是常规表达式,还可以是一个代码块,通过 yield 指定返回值。...没有记录类型之前,创建一个具有各字段对应 getter、为所有字段初始化构造函数、基于所有字段 equals()/hashCode()/toString() 简单却需要写一大堆代码,其中大部分都是样板代码...除了名、字段类型字段名之外,其他全部都是样板代码。...当然语言需要渐进式演化,这也是情理之中事。唯有两点我觉得有些遗憾: 安全 隔壁 C# 8 引入安全经验告诉我们: 即便语言当初做了错误设计,假如迷途知返,仍然能够回到正轨。

1.3K20

Table API&SQL基本概念及使用介绍

相反,我们建议将Flink配置为系统加载器包含flink-table依赖关系。这可以通过将./opt文件夹flink-table.jar文件复制到./lib文件夹完成。...以下列表概述了不同选项功能: Row:字段通过位置,任意数量字段映射,支持值,无类型安全访问。 POJO:按名称映射字段(POJO字段必须命名为表字段),任意字段数,支持值,类型安全访问。...Case Class:字段按位置映射,不支持值,类型安全访问。 Tuple:字段通过位置映射,限制为22(Scala)或25(Java)字段,不支持值,类型安全访问。...Atomic Type:表必须有单个字段,不支持值,类型安全访问。 4.1 将表转换为DataStream 作为流式查询结果表将被动态地更新,即当新记录到达查询输入流时,它会改变。...和Java)和Case Class(仅限Scala) Flink支持Scala内置元组,并为Java提供自己元组

6.3K70
您找到你想要的搜索结果了吗?
是的
没有找到

Null 值及其处理方式

但你一旦对一个 null 调用任何方法,或者进行拆箱,就会导致一个 NullPointerException 抛出。Java 虚拟机规范甚至确保它会以一个形式存在 4。...这个处理咋看之下非常奇怪,但这其实与 Java 编程模型有关, Java 类型除了少数几个基本类型之外都是类型,而我们无法像在 C++ 那样直接操作类型值,我们只能隐式地操作指针,而这个...至于 Python 这边,就比 Java 要好点,因为 Python 是动态类型语言,所以不用考虑搞什么特殊值表示 null,直接用一个特殊对象表示就可以了,只要大家约定好,都用一个类型一个表示...但编译器通过一个表达式进行对可类型特殊处理,总觉得是一个比较怪异事情,怪异点在于这仅仅支持最简单情形,稍微复杂一点就不行了,让人觉得失去了统一性,例如在 Kotlin ,这样代码是非法...它们使用参数化类型表示 null 这个概念。例如在 Scala ,有一个 Option[T] 8 类型,对于一个能为对象,不将其类型设置为 T 而是设置为 Option[T]。

1.1K40

java指针报错_指针异常是什么意思

大家好,又见面了,我是你们朋友全栈君。 Java 任何对象都有可能为,当我们调用对象方法时就会抛出 NullPointerException 指针异常,这是一种非常常见错误类型。...,当结果为时,不要返回 null 值,而是返回一个集合;如果返回值类型是对象,则可以选择抛出异常。...其它 JVM 语言中指针异常 Scala 语言中 Option 可以对标 Java 8 Optional。它有两个子类型,Some 表示有值,None 表示。...: opt match { case Some(text) => println(text) case None => println("default") } Scala 集合处理函数库非常强大,Option...结论 以上这些方案,我比较推荐使用注解预防空指针异常,因为这种方式十分有效,对代码侵入性也较小。

2.2K30

学好Spark必须要掌握Scala技术点

ScalaOption类型样例用来表示可能存在或也可能不存在值(Option子类有Some和None)。...、对象、继承和trait 3.1 3.1.1 定义 Scala,可以定义、以函数定义函数、可以定义object;可以函数定义成员缺省访问级别是:public...,可以主构造器字段赋值,对于主构造器参数已赋值new时候可以不再赋值 private[com.bigdata] class Study{}:只有com.bigdata或其子包下能访问Stu...[C] C.class 3.2 对象 3.2.1 单例对象和伴生对象 1.单例对象 Scala没有静态方法和静态字段,但是可以使用object这个语法结构达到同样目的。...主要作用: 1)存放工具方法和常量 2)高效共享单个不可变实例 3)单例模式 2.伴生对象 单例对象,不需要new,用【名.方法】调用单例对象方法 伴生对象 scala,与名相同且与该类一个文件对象叫伴生对象

1.5K50

大数据--scala学习第一章:基础第二章:控制结构和函数第三章:数组第四章:字典和元组第五章:第六章:对象第七章:包和引入第八章:继承第九章文件和正则表达式第十章特质:接口第十一章操作符第十二章函

如果带参数则在名后()定义,如果使用表5.1定义参数,将在字段,如果包含val和var,没有方法使用情况下改参数只用于语句访问,如果方法使用了就是对象私有字段。...等 7、闭包:闭包确保Scala可以访问非局部变量,比如上面的mulByfactor即是这样一个变量,通过赋值不同值不同调用会不一样。...可变序列与java大体类似 4、列表:Scala列表要么是要么是一个head元素加上一个tail元素而tail元素又是一个链表,我思路是:嵌套链表,以head开始tail嵌套。...2、模式变量:case关键字后面可以跟着一个变量名,那么匹配表达式会赋值给那个变量,其实全部匹配就是一个变量只是变量名为。同样你也可以守卫中使用变量。...模式匹配时可以将类型为Amount对象和样例进行匹配,然后参数会直接绑定然后直接用样例变量如下: amout math{ case Dollar(v)=>"$"+v case

4.4K20

Scala语言入门:初学者基础语法指南

} Scala 2,也可以通过创建一个扩展App对象定义主程序。...密封限制了可扩展子类类型,并在模式匹配确保所有可能类型都被处理,提高了代码安全性和可靠性。...协变和逆变是用来指定泛型类型参数类型关系方式,以确保类型安全性。 协变 协变(Covariance): 协变表示类型参数类型关系具有相同方向。...通过协变和逆变,我们可以 Scala 实现更灵活类型关系,并确保类型安全性。这在处理泛型集合或函数参数时特别有用。...通过类型上界和类型下界,我们可以对泛型类型参数范围进行限制,以确保类型约束和类型安全性。这使得我们能够编写更灵活、可复用且类型安全代码。

25720

- Actor 与并发

"actor test2" } } 输出: actor test1 这种用法实际并不常用,需要: 扩展超 Actor 重载 act 方法 调用扩展对象 start 方法 使用 scala.actors.Actor.actor...良好 Actor 风格 只通过消息与 actor 通信 举个例子,一个 GoodActor可能会在发往 BadActor 消息包含一个指向自己引用,表明作为消息源自己。...结果是,你需要确保 BadActor 线程对这些实例数据读取和 GoodActor 线程对这些数据写入是同步一个锁上。一旦绕开了 actor 之间消息传递机制,就回到了共享数据和锁模型。...优选不可变消息 由于 Scala actor 模型提供了每个 actor act 方法单线程环境,不需要担心在这个方法实现中使用对象是否是线程安全。...确保消息对象是线程安全最佳途径是消息中使用不可变对象。任何只有 val 字段且这些字段只引用到不可变对象实例都是不可变

55510

Scala语言入门:初学者基础语法指南

} Scala 2,也可以通过创建一个扩展App对象定义主程序。...密封限制了可扩展子类类型,并在模式匹配确保所有可能类型都被处理,提高了代码安全性和可靠性。...协变和逆变是用来指定泛型类型参数类型关系方式,以确保类型安全性。 协变 协变(Covariance): 协变表示类型参数类型关系具有相同方向。...通过协变和逆变,我们可以 Scala 实现更灵活类型关系,并确保类型安全性。这在处理泛型集合或函数参数时特别有用。...通过类型上界和类型下界,我们可以对泛型类型参数范围进行限制,以确保类型约束和类型安全性。这使得我们能够编写更灵活、可复用且类型安全代码。

26520

Scala语言入门:初学者基础语法指南

} Scala 2,也可以通过创建一个扩展App对象定义主程序。...密封限制了可扩展子类类型,并在模式匹配确保所有可能类型都被处理,提高了代码安全性和可靠性。...协变和逆变是用来指定泛型类型参数类型关系方式,以确保类型安全性。 协变 协变(Covariance): 协变表示类型参数类型关系具有相同方向。...通过协变和逆变,我们可以 Scala 实现更灵活类型关系,并确保类型安全性。这在处理泛型集合或函数参数时特别有用。...通过类型上界和类型下界,我们可以对泛型类型参数范围进行限制,以确保类型约束和类型安全性。这使得我们能够编写更灵活、可复用且类型安全代码。

42810

Scala语言入门:初学者基础语法指南

密封限制了可扩展子类类型,并在模式匹配确保所有可能类型都被处理,提高了代码安全性和可靠性。...协变和逆变是用来指定泛型类型参数类型关系方式,以确保类型安全性。协变协变(Covariance): 协变表示类型参数类型关系具有相同方向。...如果一个泛型类型参数是协变,那么子类型关系将保持不变,即父类型可以被替换为子类型 Scala ,可以使用 + 符号表示协变。...通过协变和逆变,我们可以 Scala 实现更灵活类型关系,并确保类型安全性。这在处理泛型集合或函数参数时特别有用。...通过类型上界和类型下界,我们可以对泛型类型参数范围进行限制,以确保类型约束和类型安全性。这使得我们能够编写更灵活、可复用且类型安全代码。

28220

hello Kotlin

从外观上,乍一看还以为是 Scala,我曾经琢磨着把 Scala 作为我下一门语言,不过想想用 Scala 干嘛呢,我又不做大数据,而它又太复杂了o(╯□╰)o 用Kotlin创建一个数据 ?...安全和不可变类型使得开发对变量定义和初始化倾注了更多关注 啊啊,我再也不用写那个 findViewById 了,真的爽爆有木有!...3.2 安全与属性代理 第一次见到类型安全设计是 Swift 当中,那时候还觉得这个东西有点儿意思哈,一旦要求变量不能为以后,因它而导致指针异常可能性就直接没有了。...想想每次 QA 提 bug 吧,说少了都得有三分之一是指针吧。 Kotlin 安全设计,主要是类型后面加?表示可,否则就不能为 null。...我们再来回头看一下 debug 这个方法,我们发现它可以通过泛型参数 T 获取到T具体类型,并且拿到它名——当然,如果你愿意,你甚至可以调用它构造方法构造一个对象出来——为什么 Kotlin

89850

Android开发必备知识:为什么说Kotlin值得一试

从外观上,乍一看还以为是 Scala,我曾经琢磨着把 Scala 作为我下一门语言,不过想想用 Scala 干嘛呢,我又不做大数据,而它又太复杂了o(╯□╰)o 用Kotlin创建一个数据 ?...安全和不可变类型使得开发对变量定义和初始化倾注了更多关注 啊啊,我再也不用写那个 findViewById 了,真的爽爆有木有!...3.2 安全与属性代理 第一次见到类型安全设计是 Swift 当中,那时候还觉得这个东西有点儿意思哈,一旦要求变量不能为以后,因它而导致指针异常可能性就直接没有了。...想想每次 QA 提 bug 吧,说少了都得有三分之一是指针吧。 Kotlin 安全设计,主要是类型后面加?表示可,否则就不能为 null。...我们再来回头看一下 debug 这个方法,我们发现它可以通过泛型参数 T 获取到T具体类型,并且拿到它名——当然,如果你愿意,你甚至可以调用它构造方法构造一个对象出来——为什么 Kotlin

1.1K90

Play For Scala 开发指南 - 第8章 用户界面

</h1> ()用于插入单行代码,插入结果为当前表达式值;而{}用于插入多行代码,插入结果为最后一行表达式值。 由于模板文件参与编译过程,并且是类型安全,所以编译器会帮你拦住大部分错误。...而在Twirl则没有上下文概念,模板函数仅仅是一个普通函数,没有复杂上下文状态存在,这种无状态设计更加简洁并易于理解,不仅方便测试,而且大大提升了模板层可用性,我们不仅可以 Controller... } 处理表单 用户浏览器端通过Html表单填充业务数据并提交至服务器端进行处理,与之对应,Play 服务器端提供了 Form 用于处理与Html表单相关操作: 数据绑定 数据校验...nonEmptyText: 映射为非 scala.String 类型, 可以使用 minLength 和 maxLength 参数限定长度。...,严重影响了前后端分离开发,所以实际开发建议使用 helper 工具包,而是直接编写 Html 代码: @(userForm: Form[(String, String)]) <form action

1.5K20

scala快速入门系列【模式匹配】

---- 模式匹配 scala中有一个非常强大模式匹配机制,可以应用在很多场景: switch语句 类型查询 使用模式匹配快速获取数据 简单模式匹配 Java,有switch...---- 匹配类型 除了像Javaswitch匹配数据之外,match表达式还可以进行类型匹配。如果我们要根据不同数据类型执行不同逻辑,也可以使用match表达式实现。...例如:要匹配0-7,就需要写8个case语句出来。例如: ? scala,可以使用守卫简化上述代码——也就是case语句中添加if条件判断。...---- 匹配样例 scala可以使用模式匹配匹配样例,从而可以快速获取样例成员数据。后续,我们开发Akka案例时,还会用到。...示例 创建两个样例Customer、Order – Customer 包含姓名,年龄字段 – Order包含id字段 分别定义两个案例对象,并指定为Any类型 使用模式匹配这两个对象,并分别打印它们成员变量值

76010

(3) - Scala case class那些你不知道知识

你可能知道知识 当你声明了一个 case class,Scala 编译器为你做了这些: 创建 case class 和它伴生 object 实现了 apply 方法让你不需要通过 new 创建实例...由于 == Scala 总是代表 equals,所以 case class 实例总是可比较 scala> val p_1 = new Person( "Brown", "John", 1969...( a ) A:1 scala> classMath( b ) B:b 也许你已经知道,模式匹配,当你 case class 没有参数时候,你是使用 case object 而不是一个参数列表...case class scala> classMath( A ) A(100) 除了模式匹配中使用之外,unapply 方法可以让你结构 case class 提取它字段,如: scala...上文提到所有 case class 特性在这种定义方式下只作用于第一个参数列表参数(比如在参数前自动加 val,模式匹配,copy 支持等等),第二个及之后参数列表参数和普通 class

39210

Scala学习二-面向对象

javamain方法是静态,而在scala没有静态方法,所以scala,main方法必须放在一个单例对象。...class和obect具有相同名字,这个object称为伴生对象,这个class称为伴生 注意: 伴生对象必须要和伴生一样名字 伴生对象和伴生一个scala源文件 伴生对象和伴生可以相互访问...,支持创建对象时候,可以写new操作,要想实现写new操作,就需要通道伴生对象appky方法实现 定义apply方法 object 伴生对象名{ def apply(参数名:参数类型...Scala代码可以子类中使用override重写父成员,也可以使用super引用父成员.可以使用override重新一个val字段。...3.与特质之间是继承关系,只不过之间只支持单继承,但是与特质之间,既可以单继承,也可以多继承 4.Scala特质可以有普通字段, 抽象字段, 普通方法, 抽象方法. trait 特质名称

86921

Scala语言快速了解一下?

静态类型Scala具备类型系统,通过编译时检查,保证代码安全性和一致性。...用作返回任何结果方法结果类型。Unit只有一个实例值,写成()。Nullnull 或引用NothingNothing类型Scala层级最底端;它是任何其他类型类型。...Null是null引用对象类型,它是每个引用(继承自AnyRef子类。Null兼容值类型。变量 Scala ,使用关键词 "var" 声明变量,使用关键词 "val" 声明常量。...Scala 通过参数类型之后放一个星号设置可变参数(可重复参数)。...子类重写超抽象方法时,你不需要使用override关键字。Scala 使用 extends 关键字继承一个,继承会继承父所有属性和方法,Scala 只允许继承一个

3K102

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

Nil代表一个List类型,等同List[Nothing],根据List定义List[+A],所有Nil是所有List[T]子类; Null是所有AnyRef子类,Scala类型系统,AnyRef...当函数参数个数有多个,或者固定时候,可以使用vararg参数,具体使用方式是参数类型后面加一个“*”,相应参数函数体中就是一个集合,根据需要对参数进行解析。...Option类型表示一个存在与否,一般程序需要返回一个对象时候,使用Option类型,如果返回null,程序会引起异常,而Option就不会。...有区别的,不加关键字的话,这个参数只能用于实例化,一旦实例化后这些参数就不可以使用了,如果加关键字的话这些参数就成为一个字段。 30 case class(样本类)是什么?...抽象普通基础上增加了abstract关键字,无法对其进行实例化,它是用来被子类继承,抽象可以只定义字段和方法,具体值和实现在其子类实现,子类也可以进行重写。

2.1K20
领券