Scala 深入浅出实战经典 第78讲:Type与Class实战详解

时间:2022-05-04 12:45:02

王家林亲授《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/2vZ06RMcD6I/
优酷:http://v.youku.com/v_show/id_XMTMwMjMwNzQyOA==.html?from=s1.8-1-1.2
爱奇艺:http://www.iqiyi.com/w_19rthigxsl.html#vfrm=2-3-0-1
腾讯视频:http://v.qq.com/boke/page/a/0/z/a0161iknfoz.html
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群

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

微信公众账号: DT_Spark
王家林老师微信号: 18610086859
王家林老师QQ: 1740415547
王家林老师邮箱: 18610086859@126.com

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

package com.parllay.scala.bestpractive
import scala.reflect.runtime.universe._
/**
* Created by richard on 15-9-1.
* 第78讲:Type与Class实战详解
*/

class Spark
trait Hadoop
object Flink
class Java{
class Scala
}

/**
* type 与 class区别:
* type比class更具体。任何数据都有type。但是class是一种数据结构,或数据 结构的抽象。 更宏观。但type更具体
* classOf与getClass区别:
* 1: getClass是获得类的子类,classOf是类型本身
* 2: object的getClass是class 包名加类名加$。
* 所以object是有具体的类的
* object的classOf报错, typeOf报错.
*/
object Type_Advanced {

def main(args: Array[String]) {

println(typeOf[Spark])
println(classOf[Spark])

val spark = new Spark
//println(spark.getClass == classOf[spark])
//classOf是具体的类的操作,而spark是实例本身所以有问题;

println(classOf[Hadoop])
println(typeOf[Hadoop])

//以下正确
println(Flink.getClass)
//以下错误
//println(classOf[Flink])
//println(typeOf[Flink])

val java1 = new Java
val java2 = new Java
val scala1 = new java1.Scala
val scala2 = new java2.Scala

println(scala1.getClass)//class 包名 类名
println(scala2.getClass)//class 包名类名
println(typeOf[java1.Scala]==typeOf[java2.Scala])//false
println(typeOf[java1.Scala])//java1.Scala
println(typeOf[java2.Scala])//java2.Scala
println(classOf[List[Int]]==classOf[List[String]])//true
println(typeOf[List[Int]]==typeOf[List[String]])//false
//type显示的是更具体到对象的类型,而class只是类类型

}

}