Scala Types 2
存在类型
形式:
forSome { type ... }
或forSome { val ... }
主要为了兼容 Java 的通配符
示例
Array[_]
// 等价于
Array[T] forSome { type T} Map[_, _]
// 等价于
Map[T, U] forSome { type T; type U <: T}
类型系统
类型 | 语法 |
---|---|
Class/Trait | class C , trait T |
元组 | (T1, T2...) |
函数 | (P1, P2...) => T |
注解 | T @A |
参数类型 | A[T1, T2...] |
单例类型 | value.type |
类型投射 | O#I |
组合类型 | T1 with T2 ... |
中缀类型 | T1 A T2 |
存在类型 | T forSome { type/val... } |
以上类型可在编写程序时定义,Scala 也有少量的类型在编译器内部使用
def square(x: Int) = x * x
// REPL 中返回的类型为
// square(x: Int) Int
// 省略的方法定义的 =>
自身类型 self type
形式:
this: Type =>
用于限制
trait
只能被混编于指定类型的子类中trait T1 { def m1()} trait T2 extends T1 {
this: Super1 with Super2 =>
def m1() { methodInSuper() }
} // 使用时只能在 Super1,Super2 的子类中混编 with T2
引入的问题:自身类型不会自动继承,必须在子类中重复定义
trait T3 extends T2 {
this: Super1 with Super2 => // 必须重复定义
}
依赖注入
通过
trait
和 自身类型 实现简单的以来注入- 需要将所有的依赖都组合起来
trait Logger { def log(msg: String) } trait Auth {
this: Logger =>
def login(id: String, password: String): Boolean
} trait App {
this: Logger with Auth =>
// ...
} object MyApp extends App with FileLogger("test.log") with MockAuth("users.txt")
蛋糕模式 (
cake pattern
) 实现依赖注入- 依赖的组件使用自身类型来表示
trait
描述服务接口val
定义需要实例化的服务- 层级化组合各个组件,在一个整体中注入需要的组件
// 定义组件1
trait LoggerComponent {
// 描述接口
trait Logger { ... }
// 需要实例化的服务
val logger: Logger
// 接口具体实现
class FileLogger(file: String) extends Logger { ... }
...
} // 定义组件2
trait AuthComponent {
// 自身类型限定混编使用的类型
this: LoggerComponent => // Gives access to logger
// 定义服务接口
trait Auth { ... }
// 需要实例化的服务
val auth: Auth
// 接口具体实现
class MockAuth(file: String) extends Auth { ... }
...
}
// 所有的依赖都集中在一处进行配置/注入
object AppComponents extends LoggerComponent with AuthComponent {
// 实例化服务/注入
val logger = new FileLogger("test.log")
val auth = new MockAuth("users.txt")
}
抽象类型
形式:
type Name
在
class
或trait
中定义场景:具体类型需要在子类中确定
trait Reader {
type Contents
def read(fileName: String): Contents
}
// 子类实现是具体确定类型
class StringReader extends Reader {
type Contents = String
def read(fileName: String) = ...
} class ImageReader extends Reader {
type Contents = BufferedImage
def read(fileName: String) = ...
}
抽象类型、类型参数的使用选择
- 在类实例化时需要具体确认类型的场景使用类型参数,如
HashMap[String, Int]
- 期望子类提供具体类型的场景使用抽象类型,如上例中的
Reader
- 在类实例化时需要具体确认类型的场景使用类型参数,如
Scala Types 2的更多相关文章
- Scala: Types of a higher kind
One of the more powerful features Scala has is the ability to generically abstract across things tha ...
- Scala Types 1
在 Scala 中所有值都有一种对应的类型 单例类型 形式:value.type,返回类型 value / null 场景1:链式API调用时的类型指定 class Super { def m1(t: ...
- Beginning Scala study note(8) Scala Type System
1. Unified Type System Scala has a unified type system, enclosed by the type Any at the top of the h ...
- scala速成记录1
选择 Learning Scala这本书,两百多页,足够薄. 安装 http://www.scala-lang.org/ 下载Binary的版本.bin里边有所有操作系统下运行的可以运行的交互式s ...
- geotrellis使用(十九)spray-json框架介绍
Geotrellis系列文章链接地址http://www.cnblogs.com/shoufengwei/p/5619419.html 目录 前言 spray-json简介 spray-json使用 ...
- Akka(33): Http:Marshalling,to Json
Akka-http是一项系统集成工具.这主要依赖系统之间的数据交换功能.因为程序内数据表达形式与网上传输的数据格式是不相同的,所以需要对程序高级结构化的数据进行转换(marshalling or se ...
- 【原创】大叔问题定位分享(11)Spark中对大表子查询加limit为什么会报Broadcast超时错误
当两个表需要join时,如果一个是大表,一个是小表,正常的map-reduce流程需要shuffle,这会导致大表数据在节点间网络传输,常见的优化方式是将小表读到内存中并广播到大表处理,避免shuff ...
- Spark SQL 函数全集
org.apache.spark.sql.functions是一个Object,提供了约两百多个函数. 大部分函数与Hive的差不多. 除UDF函数,均可在spark-sql中直接使用. 经过impo ...
- org.apache.spark.sql.functions汇总
测试数据: id,name,age,comment,date 1,lyy,28,"aaa bbb",20180102020325 scala> var data = spar ...
随机推荐
- 怎么进入bios设置界面,电脑如何进入BIOS进行设置,怎么进入BIOS的方法集合
怎么进入bios设置界面,电脑如何进入BIOS进行设置,怎么进入BIOS的方法集合 开机出现电脑商家图标时,按住F10键进入BIOS界面.进入BIOS界面一般都是开机后按<del,Esc,F1, ...
- maven 学习---使用Maven清理项目
在基于Maven的项目中,很多缓存输出在“target”文件夹中.如果想建立项目部署,必须确保清理所有缓存的输出,从面能够随时获得最新的部署. 要清理项目缓存的输出,发出以下命令: mvn clean ...
- 1.说一下的 dubbo 的工作原理?注册中心挂了可以继续通信吗?说说一次 rpc 请求的流程?
作者:中华石杉 面试题 说一下的 dubbo 的工作原理?注册中心挂了可以继续通信吗?说说一次 rpc 请求的流程? 面试官心理分析 MQ.ES.Redis.Dubbo,上来先问你一些思考性的问题.原 ...
- 【分布式搜索引擎】Elasticsearch之如何安装Elasticsearch
在Macos上安装 一.下载安装过程 最新版本下载地址: https://www.elastic.co/cn/downloads/elasticsearch 历史版本下载地址: https://www ...
- [TCP/IP] 关闭连接后为什么客户端最后还要等待2MSL
MSL(Maximum Segment Lifetime)报文最大生存时间,2MSL即两倍的MSL,TCP允许不同的实现可以设置不同的MSL值. 第一,保证客户端发送的最后一个ACK报文能够到达服务器 ...
- Jquery ajax 同步阻塞引起的UI线程阻塞的坑(loading图片显示不出来,layer.load延迟)
今天想做一个点击地市用ajax重新获取数据刷新页面功能,因为ajax属于耗时操作,想在获取数据且加载页面时显示加载遮罩层,结果发现了ajax的好多坑. 例如如上栗子,我想点击按钮让遮罩层显示,ajax ...
- 06webpack-- html-webpack-plugin的2个作用
<!-- 15 html-webpack-plugin的2个作用 下载 cnpm i html-webpack-plugin -D 作用在==>内存中生成页面 在webpack中 导入在内 ...
- c# 第9节 数据类型之引用类型
本节内容: 1:数据类型之引用类型 2:字符串要注意的两点: 1:数据类型之引用类型 实例: 2:字符串要注意的两点: 对变量进行重新赋值:其原本的字符串并没有销毁
- 201777010217-金云馨《面向对象程序设计Java》第四周总结学习
2019面向对象程序设计(Java)第4周学习指导及要求 项目 内容 这个作业属于哪个课程 <任课教师博客主页链接>https://www.cnblogs.com/nwnu-daizh/ ...
- 201871010101-陈来弟《面向对象程序设计(Java)》第八周学习总结
实验七 接口的定义与使用 第一部分:理论知识 一.接口.lambda和内部类: Comparator与comparable接口: 1.comparable接口的方法是compareTo,只有一个参数 ...