/**
 * 如果有这些语法的支持,我们说这门语言是支持面向对象的语言
 * 其实真正面向对象的精髓是不是封装、继承、多态呢?
 * --->肯定不是,封装、继承、多态,只不过是支撑面向对象的
 * 一些语言级别的语法和功能,真正的面向对象其实有三个核心特征:
 * 第一:对象不用关心消息从哪里来,也不关心消息到哪去,只关心消息处理本身
 * ,也就是说面向对象是弱耦合的且对象是消息驱动的,或者说对象是数据驱动的
 * 第二:一个对象的行为不影响另一个对象的行为,一个对象挂掉了另一个对象
 * 不会随着它一起挂掉
 * 第三:面向接口编程,为了封装具体实现的不同和业务的变化
 * 那么从这个角度讲,Java语言和Scala语言都不是面向对象的语言,Java和Scala
 * 都是"支持"面向对象的语言,它用他的封装、继承、多态来支持面向对象的三大核心特征
 * 或者说功能
 * 
 * 函数:不依赖于类的
 * 
 * 1.在Scala中定义类是用class关键字
 * 2.可以使用new ClassName的方式构建出类的对象
 * 3.如果名称相同,则object中的内容都是class的静态,也就是说
 * object中的内容class都可以在没有实例的时候直接去调用,正是
 * 因为可以在没有类的实例的时候去调用object中的一切内容,所以可以
 * 使用object中的特定方法来创建类的实例,而这个特定方法就是apply方法
 * 4.object中的apply方式是class对象生成的工厂方法,用于控制对象的生成
 * 5.很多框架的代码一般直接调用抽象类的object的apply方法来生成类的实例对象,
 * 第一:其秘诀在于apply具有类的对象生成的一切生杀大权,抽象类是不可以直接实例化的,在
 * apply方法中可以实例化抽象类的子类,以Spark中的图计算为例,Graph是抽象类的
 * class,在object Graph中的apply方法实际上是调用了Graph的子类GraphImpl
 * 来构建Graph类型的对象实例的,当然从Spark图计算的源码可以看出,GraphImpl
 * 的构造是使用了object GraphImpl的apply方法
 * 第二:这种方式神奇的效应在于更加能够应对代表版本迭代或者修改的变化,这是更高意义
 * 的接口编程
 * 6.object C7是class C7的伴生对象,class C7可以直接访问
 * object C7中的一切内容,而class C7是object C7的伴生类
 * ,object C7可以直接访问class C7的一切内容,一个特例是private[this]
 * 修饰的成员,我们会在后面讲解
 * 7.在定义Scala的class的时候可以直接在类名后面()里加入类的构造参数,此时在
 * apply方法中也必须有这些参数
 * 8.Scala中可以在object中构造很多的apply方法
 * 9.Scala中的很多集合都是使用了apply的方式构造的,例如Array
 * 
 *   def apply[T: ClassTag](xs: T*): Array[T] = {
 *     val array = new Array[T](xs.length)
 *     var i = 0
 *     for (x <- xs.iterator) { array(i) = x; i += 1 }
 *     array
 *   }
 * 
 */ 
---------------------
作者:张涵钧
来源:CSDN
原文:https://blog.csdn.net/shunhack/article/details/52587834
版权声明:本文为博主原创文章,转载请附上博文链接!

Scala实战高手****第7课:零基础实战Scala面向对象编程及Spark源码解析的更多相关文章

  1. Scala实战高手****第5课:零基础实战Scala函数式编程及Spark源码解析

    Scala函数式编程 ----------------------------------------------------------------------------------------- ...

  2. 机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理、源码解析及测试

    机器学习实战(Machine Learning in Action)学习笔记————03.决策树原理.源码解析及测试 关键字:决策树.python.源码解析.测试作者:米仓山下时间:2018-10-2 ...

  3. Scala实战高手****第4课:零基础彻底实战Scala控制结构及Spark源码解析

    1.环境搭建 基础环境配置 jdk+idea+maven+scala2.11.以上工具安装配置此处不再赘述. 2.源码导入 官网下载spark源码后解压到合适的项目目录下,打开idea,File-&g ...

  4. Scala实战高手****第6课 :零基础实战Scala集合操作及Spark源码解析

    本课内容1.Spark中Scala集合操作鉴赏2.Scala集合操作实战 --------------------------------------------------------------- ...

  5. 「从零单排canal 04」 启动模块deployer源码解析

    基于1.1.5-alpha版本,具体源码笔记可以参考我的github:https://github.com/saigu/JavaKnowledgeGraph/tree/master/code_read ...

  6. spark源码解析之scala基本语法

    1. scala初识 spark由scala编写,要解析scala,首先要对scala有基本的了解. 1.1 class vs object A class is a blueprint for ob ...

  7. Scala实战高手****第8课:零基础实战Scala最常用数据结构Map和Tuple及Spark源码鉴赏

    本课内容1.Map和Tuple在Spark源码中的鉴赏2.Map和Tuple代码操作实战 ------------------------------------------------------- ...

  8. Scala实战高手****第12课:Scala函数式编程进阶(匿名函数、高阶函数、函数类型推断、Currying)与Spark源码鉴赏

    /** * 函数式编程进阶: * 1.函数和变量一样作为Scala语言的一等公民,函数可以直接赋值给变量 * 2.函数更常用的方式是匿名函数,定义的时候只需要说明输入参数的类型和函数体即可,不需要名称 ...

  9. Scala 深入浅出实战经典 第65讲:Scala中隐式转换内幕揭秘、最佳实践及其在Spark中的应用源码解析

    王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...

随机推荐

  1. webpack 引入 html-webpack-plugin 报错

    配置webpack当中,出现一个问题: 引入html-webpack-plugin 插件报错. 这时需要本地(也就是当前项目下)安装一下webpack就可以解决问题了. 注意:现在是webpack4版 ...

  2. ES6学习笔记(一)——Promise

    Promise 是 ES6 提供的一种异步编程的解决方案: 将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数(解决异步函数回调地狱的问题).Promise 对象保存着异步操作的结果. 首先 ...

  3. Flink源码阅读(一)--Checkpoint触发机制

    Checkpoint触发机制 Flink的checkpoint是通过定时器周期性触发的.checkpoint触发最关键的类是CheckpointCoordinator,称它为检查点协调器. org.a ...

  4. sql 批量更新表中多字段为不同的值

    ,),,),rand()) select newid() ,) update tablename , FB,)) , ), FC,)) , )

  5. centos6.4 nginx+mysql+php整合phpmyadmin出错解决方案

    今天在centos下整合phpmyadmin出错,错误提示如下: Error during session start; please check your PHP and/or webserver ...

  6. 全局axios默认值 和 自定义实例默认值

    首先说了一下情况, 登录后成功返回token 然后在带着token去继续下面的请求, 奇怪的是都是当前页面起作用,刷新和跳转之后就token 就消失了. 查了 axios文档发现 被自己坑了 我设置了 ...

  7. 【 Python 】函数的参数

    一.默认参数: 默认参数可以简化函数的调用,设置默认参数时,有几点要注意: 1,必选参数在前,默认参数在后,否则python的解释器会报错. 2,如何设置默认参数. 当函数有多个参数时,把变化大的参数 ...

  8. Solidity 文档--目录

    Solidity是一种语法类似JavaScript的高级语言.它被设计成以编译的方式生成以太坊虚拟机代码.在后续内容中你将会发现,使用它很容易创建用于投票.众筹.封闭拍卖.多重签名钱包等等的合约. 注 ...

  9. KVM(三)I/O 全虚拟化和准虚拟化

    在 QEMU/KVM 中,客户机可以使用的设备大致可分为三类: 1. 模拟设备:完全由 QEMU 纯软件模拟的设备. 2. Virtio 设备:实现 VIRTIO API 的半虚拟化设备. 3. PC ...

  10. node.js的全局变量的注意

    在node.js中,如果一个变量没有用var来声明,就会变为全局变量: 看如下代码: 1)6.js function myadd(a) { return a+abc; } function conta ...