第58讲:Scala中Abstract Types实战详解

package com.parllay.scala.type_parameterizitor

import scala.io.{Source, BufferedSource}

/**
 * Created by richard on 15-8-17.
 * 第58讲:Scala中Abstract Types实战详解
 */

/**
 * scala里的类型,除了在定义class,trait,object时会产生类型,
 * 还可以通过type关键字来声明类型。

type相当于声明一个类型别名:

scala> type S = String
defined type alias S
上面把String类型用S代替,通常type用于声明某种复杂类型,或用于定义一个抽象类型。

场景1 用于声明一些复杂类型,比如下面声明一个结构类型

scala> type T = Serializable {
 |          type X
 |          def foo():Unit
 |     }
defined type alias T
这个结构类型内部也允许通过type来定义类型,这里对X没有赋值表示X是一个抽象类型,
需要子类型在实现时提供X具体的类型。下面是一个T类型的具体实例:

scala> object A extends Serializable{ type X=String; def foo(){} }

scala> typeOf[A.type] <:< typeOf[T]
res19: Boolean = true
场景2 用于抽象类型

scala> trait A { type T ; def foo(i:T) = print(i) }

scala> class B extends A { type T = Int }

scala> val b = new B

scala> b.foo(200)
200

scala> class C extends A { type T = String }

scala> val c = new C

scala> c.foo("hello")
hello
 */
trait Reader{
  type In <: java.io.Serializable
  type Contents
  def read(in: In): Contents
}

class FileReader extends Reader {
  type In = String
  type Contents = BufferedSource
  override  def read(name : In) = Source.fromFile(name)
}
object Abstract_Type {

  def main(args: Array[String]) {
    val fileReader = new FileReader
    val content = fileReader.read("path")
  }

}

  

王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频、PPT、代码下载:

百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
土豆:http://www.tudou.com/programs/view/E5QGmPvfupc/
优酷:http://v.youku.com/v_show/id_XMTI4ODEwMzM3Mg==.html?from=s1.8-1-1.2
爱奇艺:http://www.iqiyi.com/w_19rrt570q9.html#vfrm=2-3-0-1
腾讯视频:http://v.qq.com/boke/page/i/0/v/i0159zikiqv.html
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

DT大数据梦工厂① :462923555
DT大数据梦工厂②:437123764
DT大数据梦工厂③ :418110145

微信公众账号: DT_Spark
王家林老师微信号: 18610086859
王家林老师QQ: 1740415547
王家林老师邮箱: [email protected]

本视频由王家林老师, 亲自讲解, 完全通过代码实战把您带人大数据的时代.

时间: 2024-10-05 12:05:22

第58讲:Scala中Abstract Types实战详解的相关文章

Scala 深入浅出实战经典 第58讲:Scala中Abstract Types实战详解

王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载: 百度云盘:http://pan.baidu.com/s/1c0noOt6 腾讯微云:http://url.cn/TnGbdC 360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2土豆:http://www.tudou.com/programs/view/IVN4EuFlmKk/优酷:http://v.youku.com/v_show/id

Scala中Abstract Types实战详解之Scala学习笔记-48

package com.leegh.parameterization import scala.io.BufferedSourceimport scala.io.Source /** * @author Guohui Li */trait Reader { type In <: java.io.Serializable type Contents def read(in: In): Contents}class FileReader extends Reader { type In = Stri

第24讲: Scala中SAM转换实战详解

SAM 是single  abstract method的缩写,就是一些接口只有单个抽象方法 假设我们需要做一个按钮,每当按下按钮时,后台记录一次点击次数.在Java中代码实现的方式如下: package com.dt.scala.func import javax.swing.JButton import java.awt.event.ActionListener import java.awt.event.ActionEvent import javax.swing.JFrame objec

第56讲:Scala中Self Types实战详解

今天学习了self type的内容,让我们来看下代码 package scala.learn class Self{  self =>    val tmp = "Scala"    def foo = self.tmp + this.tmp} trait S1class S2 {this:S1 =>}class S3 extends S2 with S1 trait T {this:S1 =>} object S4 extends T with S1object t

DT梦工厂 第24讲 scala中sam转换实战详解

王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 腾讯微云:http://url.cn/TnGbdC 360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2土豆:http://www.tudou.com/programs/view/dHz5JKJxurM/优酷:http://v.youku.com/v_show/id_

Spark经典视频之Scala中Self Types实战详解

王家林亲授<DT大数据梦工厂>大数据实战视频"Scala深入浅出实战经典"视频.音频和PPT下载! 欢迎广大Spark爱好者学习交流.也欢迎广大学习爱好者加入DT大数据梦工厂交流群:462923555DT大数据微信公众账号:DT_Spark 视频观看链接http://www.tudou.com/plcover/Yy5F5gsurSE/ 视频下载地址百度云:http://pan.baidu.com/s/1eQGqzEa腾讯微云:http://url.cn/SshT6b

Scala中Self Types实战详解之Scala学习笔记-46

package com.leegh.parameterization /** * @author Guohui Li */class Self { self => val tmp = "Scala" def foo = self.tmp + this.tmp}trait S1class S2 { this: S1 => }class S3 extends S2 with S1 trait T { this: S1 => }object S4 extends T wit

Scala 深入浅出实战经典 第53讲:Scala中结构类型实战详解

王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-64讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 腾讯微云:http://url.cn/TnGbdC 360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2土豆:http://www.tudou.com/programs/view/pR_4sY0cJLs/优酷:http://v.youku.com/v_show/id_

Scala 深入浅出实战经典 第57讲:Scala中Dependency Injection实战详解

王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 腾讯微云:http://url.cn/TnGbdC 360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2土豆:http://www.tudou.com/programs/view/5LnLNDBKvi8/优酷:http://v.youku.com/v_show/id_