目录

scala面向对象

MAVEN依赖

类 - 掌握

创建类和对象 - 掌握

getter/setter - 了解

类的构造器 - 掌握


scala面向对象

MAVEN依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.itheima</groupId><artifactId>akka-demo</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.targer>1.8</maven.compiler.targer><encoding>UTF-8</encoding><scala.version>2.11.8</scala.version><scala.compat.version>2.11.8</scala.compat.version></properties><dependencies><!-- https://mvnrepository.com/artifact/org.scala-lang/scala-library --><dependency><groupId>org.scala-lang</groupId><artifactId>scala-library</artifactId><version>${scala.version}</version></dependency><!--<dependency><groupId>com.typesafe.akka</groupId><artifactId>akka-actor_2.11</artifactId><version>2.3.14</version></dependency><dependency><groupId>com.typesafe.akka</groupId><artifactId>akka-remote_2.11</artifactId><version>2.3.14</version></dependency>--></dependencies><build><sourceDirectory>src/main/scala</sourceDirectory><testSourceDirectory>src/test/scala</testSourceDirectory><plugins><plugin><groupId>net.alchim31.maven</groupId><artifactId>scala-maven-plugin</artifactId><version>3.2.2</version><executions><execution><goals><goal>compile</goal><goal>testCompile</goal></goals><configuration><args><!--<arg>-make:transitive</arg>--><arg>-dependencyfile</arg><arg>${project.build.directory}/.scala_dependencies</arg></args></configuration></execution></executions></plugin><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-shade-plugin</artifactId><version>2.4.3</version><executions><execution><phase>package</phase><goals><goal>shade</goal></goals><configuration><filters><filter><artifact>*:*</artifact><excludes><exclude>META-INF/*.SF</exclude><exclude>META-INF/*.DSA</exclude><exclude>META-INF/*.RSA</exclude></excludes></filter></filters><transformers><transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer"><resource>reference.conf</resource></transformer><transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"><mainClass></mainClass></transformer></transformers></configuration></execution></executions></plugin></plugins></build></project>

学习目标

  • 掌握scala类与object的用法
  • 掌握继承的用法
  • 掌握trait(特质)的用法

类 - 掌握

scala是支持面向对象的,也有类和对象的概念。

创建类和对象 - 掌握

  • 使用class关键字来定义类
  • 使用var/val来定义成员变量
  • 使用def来定义成员方法
  • 使用new来创建一个实例对象

示例1:

定义一个Customer类,该类包含以下成员:

成员变量

姓名(例如:张三、李四)

性别(例如:男、女)

注册时间(不可修改)(2010/03/12)

成员方法

sayHi(消息)

定义好类之后,创建该类的对象。并给该对象赋值,并打印对象中的成员,调用成员方法。

步骤

定义一个Customer类,并添加成员变量/成员方法

添加一个main方法,并创建Customer类的对象,并给对象赋值,打印对象中的成员,调用成员方法

scala代码:

class Customer {var name:String = _var sex:String = _val registerDate:Date = new Datedef sayHi(msg:String) = {println(msg)}
}object Main {def main(args: Array[String]): Unit = {val customer = new Customercustomer.name = "张三"customer.sex = "男"println(s"姓名: ${customer.name}, 性别:${customer.sex}, 注册时间: ${customer.registerDate}")customer.sayHi("你好!")}
}

var name:String = _,_表示使用默认值进行初始化

  • String类型默认值是null,Int类型默认值是0,Boolean类型默认值是false...

val变量不能使用_来进行初始化,因为val是不可变的,所以必须手动指定一个默认值

main方法必须要放在一个scala的object(单例对象)中才能执行

getter/setter - 了解

问题1:

上述的案例,创建出来一个Customer实例,就可以给name、sex这些字段进行赋值、并可以获取它们的值。这是否意味着这些字段默认都是public的呢?

为了验证上述问题,我们需要反编译scala编译出来的class文件,看一看最终编译器出来的字节码是什么样的。

使用jd-gui工具反编译Customer类

使用jd-gui反编译Main类

问题2:

是否能够生成类似于Java的getter/setter方法呢?

可以,在字段上加上@BeanProperty就可以了。

@BeanProperty
  var name:String = _             // 姓名

@BeanProperty
  val registerDate = new Date()   // 注册时间

通过查看反编译的代码,scalac编译器已经自动帮助我们添加了Java的getter/setter

scala会自动为成员变量生成scala语言的getter/setter

scala的getter为字段名(),setter为字段名_=()

要生成Java的getter/setter,可以在成员变量上加一个@BeanProperty注解,这样将来去调用一些Java库的时候很有用

类的构造器 - 掌握

  • 主构造器

类名(var/val 参数名:类型 = 默认值, var/val 参数名:类型 = 默认值){
    // 构造代码块
}

  • 辅助构造器

this来定义,例如:

this(参数名:类型, 参数名:类型) {
    ...
}

示例1:定义主构造器

class Student(_name:String, _age:Int) {var name:String = _var age:Int = _// 构造器的代码可以直接写在类中name = _nameage = _age
}

示例2:简化定义主构造器

// 在主构造器中,可以直接定义成员变量
class Student(val name:String, val age:Int)

示例3:定义辅助构造器

class Student(val name:String, val age:Int) {// 定义一个参数的辅助构造器def this(name:String) {// 第一行必须调用主构造器、其他辅助构造器或者super父类的构造器this(name, 20)}def this(age:Int) {this("某某某", age)}
}

主构造器直接在类名后面定义

主构造器中的参数列表会自动定义为私有的成员变量

一般在主构造器中直接使用val/var定义成员变量,这样看起来会更简洁

在辅助构造器中必须调用其他构造器(主构造器、其他辅助构造器)

2021年大数据常用语言Scala(二十八):scala面向对象 MAVEN依赖和类相关推荐

  1. 2021年大数据常用语言Scala(二):Scala开发环境安装

    目录 开发环境安装 安装JDK 安装scala SDK 步骤 具体操作 安装IDEA scala插件 步骤 开发环境安装 学习如何编写scala代码之前,需要先安装scala编译器以及开发工具 sca ...

  2. 2021年大数据常用语言Scala(四):基础语法学习 声明变量

    目录 声明变量 语法格式 在解释器中定义一个变量 val和var变量 使用类型推断来定义变量 惰性赋值 声明变量 我们将来每一天编写scala程序都会定义变量.那scala语言如何定义变量呢? 语法格 ...

  3. 2021年大数据常用语言Scala(三十一):scala面向对象 特质(trait)

    目录 特质(trait) 作为接口使用 定义具体的方法 定义具体方法和抽象方法 定义具体的字段和抽象的字段 实例对象混入trait trait调用链 trait的构造机制 trait继承class 特 ...

  4. 2021年大数据常用语言Scala(一):Scala简介

    目录 一.Scala简介 为什么使用scala Scala对比Java 案例 一.Scala简介 scala是运行在JVM上的多范式编程语言,同时支持面向对象和面向函数编程 多范式:就是包含多种编程思 ...

  5. 2021年大数据常用语言Scala(十八):基础语法学习 Map对象

    目录 Map对象 不可变Map 可变Map Map基本操作 Map对象 Map可以称之为映射.它是由键值对组成的集合.在scala中,Map也分为不可变Map和可变Map. 不可变Map 定义 语法 ...

  6. 2021年大数据常用语言Scala(十七):基础语法学习 Set

    目录 Set 不可变集 可变集 Set Set(集)是代表没有重复元素的集合.Set具备以下性质: 元素不重复 不保证插入顺序 和List正好相反, List: 元素可以重复 保证插入顺序 scala ...

  7. 2021年大数据常用语言Scala(六):基础语法学习 数据类型与操作符

    数据类型与操作符 scala中的类型以及操作符绝大多数和Java一样,我们主要来学习 与Java不一样的一些用法 scala类型的继承体系 数据类型 基础类型 类型说明 Byte 8位带符号整数 Sh ...

  8. 2021年大数据常用语言Scala(三):Scala解释器

    目录 scala解释器 启动scala解释器 执行scala代码 退出解释器 scala解释器 后续我们会使用scala解释器来学习scala基本语法,scala解释器像Linux命令一样,执行一条代 ...

  9. 2021年大数据常用语言Scala(二十二):函数式编程 映射 map

    目录 映射 | map 用法 案例一 案例二 映射  map 集合的映射操作是将来在编写Spark/Flink用得最多的操作,是我们必须要掌握的.因为进行数据计算的时候,就是一个将一种数据类型转换为另 ...

最新文章

  1. python excel 教程推荐_python对Excel按条件进行内容补充(推荐)
  2. python进度条 pyqt_python如何通过pyqt5实现进度条
  3. 七天免登录JavaScript实现
  4. Hyhyhy – 专业的 HTML5 演示文稿工具
  5. 中南大学在线考试答案计算机基础,中南大学《计算机基础》在线考试题库(267题)(有答案).doc...
  6. pytorch之embedding
  7. 突然!新锤子手机系统现身:这是另起炉灶了?
  8. Android生命周期帮助类,Android Service类与生命周期详细介绍_Android_脚本之家
  9. c语言实验题水仙花数5359,《C语言程序设计》实验报告(实验1-12).doc
  10. Facebook史上最严重宕机,全网宕机近七小时,到底是怎么回事?
  11. linux下telnet批量验证某端口开放
  12. UIAutomator2.0初始
  13. paramiko模块执行linux下nohup卡住的问题。
  14. 数组中只出现一次的数
  15. 智力与联系能力的关系
  16. python能做的java能做吗_java – Jython不能做什么Python?
  17. 从.snk文件导出密钥
  18. 有50 只狗,找出其中病狗
  19. 俞敏洪:一个人即使没有理想,但有2件事情肯定能做
  20. 第八节_我的日记本开发手记(8)——sqlite数据库与c#

热门文章

  1. 2022-2028年全球与中国生物质燃料粒行业市场智研瞻分析报告
  2. 2021-2027年中国一氧化氮行业市场研究及前瞻分析报告
  3. 2021-2027全球与中国奶牛冻精市场现状及未来发展趋势
  4. 第五周周记(国庆第三天)
  5. msql每个数据前面添加某个字符串查询或者更新
  6. iceberg问题小结
  7. python压缩和解压缩
  8. Pytorch的LSTM的理解
  9. 王道考研 计算机网络笔记 第六章:应用层
  10. 英伟达TensorRT 8-bit Inference推理