scala简要:高级函数和高级类型

简介: 版权声明:本文为半吊子子全栈工匠(wireless_com,同公众号)原创文章,未经允许不得转载。
版权声明:本文为半吊子子全栈工匠(wireless_com,同公众号)原创文章,未经允许不得转载。 https://blog.csdn.net/wireless_com/article/details/42343373
在scala中,函数是头等公民,可以用变量存储函数,可以使用匿名函数,和带参数的函数。如果需要一个序列的值,一般从一个简单序列转化得出。函数可以在变量不再作用域内时被调用,这样的函数叫闭包。

柯里化是指将原来接受两个参数变成接受一个参数的函数的过程。不需要用return语句来返回函数值,函数的返回值就是函数体的值。


scala中,用方括号来定义类型参数,从调用该方法的实际参数来推断出类型。视图界定 T<%V要求必须存在一个从T到V的隐式转换,Manifest对象是构造器的隐式参数,可用于上下文界定,类型变化的方向和子类型方向是相反的。

函数在参数上是逆变的,在返回值上的协变的,对象是不能泛型化的。


在内部,编译器将所有嵌套的类型表达式a.b.c.T都翻译成类型投影a.b.c.type#T。对应复杂类型,可用type关键字创建一个简单的别名,type同样被用于那些在子类中被具体化的抽象类型。

结构类型指的是一组关于抽象方法,字段和类型的规格说明,可用安全而方便的反射调用。

在scala中,通过特质和自身类型达到一个简单的依赖注入效果。如果类型是在类实例化时给出,则使用泛型,如果类型是在子类中给出,则使用抽象类型。

List这样的泛型类型有时称为类型构造器。Container特质是scala集合类库中使用的构建器机制的的简化版。

目录
相关文章
|
4月前
|
分布式计算 Scala Spark
Scala【集合常用方法和函数操作(下)】
Scala【集合常用方法和函数操作(下)】
|
4月前
|
分布式计算 Scala Spark
Scala 【集合常用方法和函数操作-上】
Scala 【集合常用方法和函数操作-上】
|
4月前
|
消息中间件 分布式计算 Java
Scala函数式编程【从基础到高级】
Scala函数式编程【从基础到高级】
|
1月前
|
IDE Java 编译器
scala的两种变量类型 var 和 val
scala的两种变量类型 var 和 val
46 2
scala的两种变量类型 var 和 val
|
3月前
|
Scala
Scala函数和方法
Scala函数和方法
13 1
|
7月前
|
前端开发 Java 程序员
Scala高级用法 3
Scala高级用法
26 0
|
7月前
|
Java Scala
Scala高级用法 2
Scala高级用法
23 0
|
7月前
|
分布式计算 Java Scala
Scala高级用法 1
Scala高级用法
37 0
|
7月前
|
机器学习/深度学习 分布式计算 Java
Scala方法和函数
Scala方法和函数
72 0
|
11月前
|
Java Scala
Scala的高级用法
Scala的高级用法