大数据技术之 Scala(3)

以下是今天学习的知识点与代码测试:

面向对象

Scala 的面向对象思想和 Java 的面向对象思想和概念是一致的。

Scala 中语法和 Java 不同,补充了更多的功能。

一、Scala

基本语法

package 包名

Scala 包的三大作用(和 Java 一样)

    1. 区分相同名字的类
    2. 当类很多时,可以很好的管理类
    3. 控制访问范围

二、包的命名

  1. 命名规则

只能包含数字、字母、下划线、小圆点.,但不能用数字开头,也不要使用关键字。

  1. 案例实操

demo.class.exec1 //错误,因为 class 关键字

demo.12a //错误,数字开头

  1. 命名规范

一般是小写字母+小圆点

com.公司名.项目名.业务模块名
  1. 案例实操

com.zpark.oa.model com.zpark.oa.controller

com.sohu.bank.order

三、包说明包语句

  1. 说明

Scala 有两种包的管理风格,一种方式和 Java 的包管理风格相同,每个源文件一个包(包名和源文件所在路径不要求必须一致),包名用“.”进行分隔以表示包的层级关系,如com.zpark.scala。另一种风格,通过嵌套的风格表示层级关系,如下

package com{ package zpark{

package scala{

}

}

第二种风格有以下特点:

    1. 一个源文件中可以声明多个 package
    2. 子包中的类可以直接访问父包中的内容,而无需导包
  1. 案例实操

四、包对象

在 Scala 中可以为每个包定义一个同名的包对象,定义在包对象中的成员,作为其对应包下所有 class 和 object 的共享变量,可以被直接访问。

1)定义

package object com{

val shareValue="share" def shareMethod()={}

}

  1. 说明

若使用 Java 的包管理风格,则包对象一般定义在其对应包下的 package.scala文件中,包对象名与包名保持一致。

如采用嵌套方式管理包,则包对象可与包定义在同一文件中,但是要保证包对象与包声明在同一作用域中。

五、导包说明

  1. 和 Java 一样,可以在顶部使用 import 导入,在这个文件中的所有类都可以使用。

  1. 局部导入:什么时候使用,什么时候导入。在其作用范围内都可以使用3)通配符导入:import java.util._
  1. 给类起名:import java.util.{ArrayList=>JL}

  1. 导入相同包的多个类:import java.util.{HashSet, ArrayList} 6)屏蔽类:import java.util.{ArrayList =>_,_}
  2. 导入包的绝对路径:new _root_.java.util.HashMap

package java { package util {

class HashMap {

}

}

}

注意

Scala 中的三个默认导入分别是

import java.lang._ import scala._ import scala.Predef._

六、类和对象

类:可以看成一个模板对象:表示具体的事物

七、定义类

1)回顾:Java 中的类

如果类是 public 的,则必须和文件名一致。一般,一个.java 有一个 public 类

注意:Scala 中没有 public,一个.scala 中可以写多个类。

  1. 基本语法
[修饰符] class 类名 {

类体

}

说明

    1. Scala 语法中,类并不声明为public,所有这些类都具有公有可见性(即默认就是public)
    2. 一个Scala 源文件可以包含多个类
  1. 案例实操

package com.zpark.chapter06

//(1)Scala 语法中,类并不声明为 public,所有这些类都具有公有可见性(即默认就是 public)

class Person {

}

//(2)一个 Scala 源文件可以包含多个类

class Teacher{

}

八、属性

属性是类的一个组成部分

  1. 基本语法
[修饰符] var|val 属性名称 [:类型] = 属性值

注:Bean 属性(@BeanPropetry),可以自动生成规范的 setXxx/getXxx 方法

案例实操

  1. 说明

在 Java 中,访问权限分为:public,private,protected 和默认。在 Scala 中,你可以通过类似的修饰符达到同样的效果。但是使用上有区别。

    1. Scala 中属性和方法的默认访问权限为 public,但 Scala 中无 public 关键字。
    2. private 为私有权限,只在类的内部和伴生对象中可用。
    3. protected 为受保护权限,Scala 中受保护权限比 Java 中更严格,同类、子类可以访问,同包无法访问。
    4. private[包名]增加包访问权限,包名下的其他类也可以使用
  1. 案例实操

九、方法

  1. 基本语法
def 方法名(参数列表) [:返回值类型] = {

方法体

}

  1. 案例实操

十、创建对象

  1. 基本语法
val | var 象名 [] = new 类型()
  1. 案例实操
    1. val 修饰对象,不能改变对象的引用(即:内存地址),可以改变对象属性的值。
    2. var 修饰对象,可以修改对象的引用和修改对象的属性值
    3. 自动推导变量类型不能多态,所以多态需要显示声明

十一、构造器

和 Java 一样,Scala 构造对象也需要调用构造方法,并且可以有任意多个构造方法。

Scala 类的构造器包括:主构造器和辅助构造器

  1. 基本语法

class  类名() // 造器

// 类 体

def this(形参列表) { // 辅助构造器

}

def this(形参列表) { //辅助构造器可以有多个...

}

}

说明:

    1. 辅助构造器,函数的名称 this,可以有多个,编译器通过参数的个数及类型来区分。
    2. 辅助构造方法不能直接构建对象,必须直接或者间接调用主构造方法。
    3. 构造器调用其他另外的构造器,要求被调用构造器必须提前声明。
  1. 案例实操
  1. 如果主构造器无参数,小括号可省略,构建对象时调用的构造方法的小括号也可以省略。

十二、构造器参数

  1. 说明

Scala 类的主构造器函数的形参包括三种类型:未用任何修饰、var 修饰、val 修饰

    1. 未用任何修饰符修饰,这个参数就是一个局部变量
    2. var 修饰参数,作为类的成员属性使用,可以修改
    3. val 修饰参数,作为类只读属性使用,不能修改
  1. 案例实操

十三、封装

封装就是把抽象出的数据和对数据的操作封装在一起,数据被保护在内部,程序的其它部分只有通过被授权的操作(成员方法),才能对数据进行操作。Java 封装操作如下,

  1. 将属性进行私有化
  2. 提供一个公共的 set 方法,用于对属性赋值
  3. 提供一个公共的 get 方法,用于获取属性的值

Scala 中的 public 属性,底层实际为 private,并通过 get 方法(obj.field())和 set 方法

(obj.field_=(value))对其进行操作。所以 Scala 并不推荐将属性设为 private,再为其设置public 的 get 和 set 方法的做法。但由于很多 Java 框架都利用反射调用 getXXX 和 setXXX 方法,有时候为了和这些框架兼容,也会为 Scala 的属性设置 getXXX 和 setXXX 方法(通过@BeanProperty 注解实现)。

十四、继承和多态

  1. 基本语法
class   extends 类名 { 类 体 }
    1. 子类继承父类的属性方法
    2. scala 是单继承
  1. 案例实操
  1. 子类继承父类的属性方法
  2. 继承的调用顺序:父类构造器->子类构造器
  1. 动态绑定

Scala 中属性和方法都是动态绑定,而Java 中只有方法为动态绑定。

案例实操(对比 Java Scala 的重写) Scala

Java

结果对比

### 回答1: 尚硅谷大数据技术scala.docx 是一份关于Scala编程语言的大数据技术文档。Scala由Martin Odersky教授于2003年创建,结合了面向对象编程和函数式编程的特点,被广泛应用于大数据领域。 Scala具有简洁、灵活、强大的特性,逐渐成为大数据领域最受欢迎的编程语言之一。它允许开发人员快速编写高效、可维护的大规模数据处理和分析代码,并能与其他大数据技术(如Hadoop、Spark等)无缝集成。 尚硅谷大数据技术scala.docx文档可能包含了Scala的基础语法、面向对象和函数式编程的概念,以及如何在大数据环境中应用Scala进行数据处理和分析的具体案例。通过学习这份文档,读者可以了解Scala的核心特点、语法规则和编程范式,以及如何使用Scala进行大数据处理和分析。 此外,尚硅谷大数据技术scala.docx文档可能还介绍了Scala大数据生态系统中的重要角色。由于Scala与Java高度兼容,许多大数据技术(如Spark)都选择Scala作为其主要开发语言。因此,掌握Scala可以为读者在大数据领域的就业和职业发展提供很大的帮助。 综上所述,尚硅谷大数据技术scala.docx是一份关于Scala编程语言在大数据领域中应用的文档,通过学习这份文档,读者可以系统地了解Scala的基础知识和应用,并将其应用于大数据处理和分析中。 ### 回答2: 尚硅谷大数据技术scala.docx是一篇关于Scala编程语言的技术文档。Scala是一种高级的多范式编程语言,结合了面向对象和函数式编程的特点。它在大数据处理、并发编程和分布式系统方面具有较高的应用价值。 该文档首先介绍了Scala的背景和特点。Scala是一种运行在Java虚拟机上的语言,因此可以无缝地与Java进行交互。Scala支持函数式编程,允许开发人员使用更简洁的代码实现复杂的功能。同时,Scala也支持面向对象编程,并提供了强大的模式匹配功能。 接着,文档介绍了Scala的基本语法和特性。Scala的语法与Java类似,但更加简洁和灵活。Scala支持强类型和类型推导,使得编码更加便捷。Scala还有很多高级特性,如高阶函数、闭包和样例类等,可以极大地提升开发效率。 文档还介绍了Scala大数据处理领域的应用。Scala可以与Apache Spark等大数据处理框架无缝集成,提供了更加高效、灵活和可扩展的编程方式。Scala的函数式编程特性使得并行计算更加容易实现,大幅提高了程序性能。 此外,文档还对Scala的社区资源和学习路径进行了介绍。Scala拥有庞大的开发者社区,有丰富的教程、文档、博客和开源项目可供参考。通过学习Scala,可以获得更广阔的职业发展空间。 总之,尚硅谷大数据技术scala.docx是一份详细介绍Scala编程语言的技术文档,内容包括了Scala的背景、语法特性、在大数据领域的应用以及学习资源等。这份文档对于想要深入了解和应用Scala的开发人员来说,是一份宝贵的参考资料。 ### 回答3: 尚硅谷大数据技术Scala.docx是一份关于Scala编程语言的技术文档。Scala是一种支持面向对象和函数式编程的静态类型编程语言,它在大数据领域中广泛应用。 这份文档首先介绍了Scala的基本特点和优势。Scala具有更为丰富的功能和表达能力,可以充分利用现有的Java库和工具。它还拥有高效的并发编程能力,方便开发者在大数据处理中实现高性能和高可扩展性。此外,Scala还支持面向对象和函数式编程的混合使用,使得代码更加简洁和可读。 文档接着介绍Scala大数据处理中的应用场景。Scala与Apache Spark等大数据处理框架紧密结合,可以通过其丰富的函数式编程特性进行大规模数据的处理和分析。Scala还提供了一套强大的集合库,方便进行数据处理和转换。同时,Scala与Java语言的兼容性也使得Java开发者可以无缝切换到Scala环境,提高开发效率。 文档还详细介绍了Scala的语法和特性。包括基本语法、数据类型、函数定义、类和对象等内容。通过简洁的示例代码和详细的解释,帮助读者快速掌握Scala的基本语法和使用方法。 最后,文档提供了一些Scala编程技巧和最佳实践。这些技巧包括优化代码性能、避免常见错误和使用一些高级特性等。这些技巧和实践可以帮助开发者更好地利用Scala进行大数据处理和开发工作。 总之,尚硅谷大数据技术Scala.docx是一份详细介绍Scala编程语言的技术文档,旨在帮助读者快速掌握Scala并在大数据领域中应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值