一、简介

  在Scala看来,一切皆是对象,对象是Scala的核心,Scala面向对象涉及到class、object、构造器等,本文就将对class中的重点内容进行介绍;

二、Scala中的类

2.1 普通类

  在Scala中定义普通类的方式如下面的示例:

class Demo{
val name:String="类"
def introduce(): Unit ={
println("这是一个"+name)
}
}

  即class+类名+{类中的内容,包括类自带的变量,自带的方法},而在class的定义中,也有一些特殊的方法:

  1、private定义私有属性和方法

  在class中定义属性或方法时在开头加上private关键词,则会将对应的属性或方法私有化,即只允许class中的方法调用该属性或方法:

//调用class中的非私有化属性和方法
object main{
def main(args: Array[String]): Unit = {
val demo = new Demo
demo.introduce()
println(demo.name)
}
} class Demo{
val name:String="类"
def introduce(): Unit ={
println("这是一个"+name)
}
}

object main{
def main(args: Array[String]): Unit = {
val demo = new Demo
//尝试调用class中的私用化属性和方法
println(demo.B)
println(demo.x)
}
} class Demo{
private val x:Int=1
def A: Int ={
B + x
}
private def B: Int ={
2
}
}

而调用非私有化的方法,虽然该方法中调用了class中的私有化属性和私有化方法,但这时代码运行是没有问题的:

object main{
def main(args: Array[String]): Unit = {
val demo = new Demo
//尝试调用class中的私用化属性和方法
println(demo.A) }
} class Demo{
private val x:Int=1
def A: Int ={
B + x
}
private def B: Int ={
2
}
}

  2、类的继承

  在Scala中,继承的关键字是extends:

object main{
def main(args: Array[String]): Unit = {
//调用父类中的introduce方法
val demoFather = new Father
demoFather.introduce
//调用子类1中继承自父类的introduce方法
val demoChild1 = new Child1
demoChild1.introduce
}
} //父类
class Father{
val name:String="father"
def introduce: Unit ={
println(name)
}
} //子类1
class Child1 extends Father{ }

  子类通过override关键字来重写父类中的方法,如果要定义子类独特的方法,直接在子类的定义中书写即可:

object main{
def main(args: Array[String]): Unit = {
//调用父类中的introduce方法
val demoFather = new Father
demoFather.introduce
//调用子类1中继承自父类的introduce方法
val demoChild1 = new Child1
demoChild1.introduce
//调用子类1中自主的新方法
demoChild1.unique
}
} //父类
class Father{
val name:String="father"
def introduce: Unit ={
println(name)
}
} //子类1
class Child1 extends Father{
//复写父类中继承来的方法和属性
override val name: String = "son"
override def introduce: Unit = {
println(name)
}
def unique: Unit ={
println("I am unique!")
}
}

  在父类中,被关键词final修饰的属性和方法不能被子类重写会提示错误:

  3、class的传入参数

  Scala中的class可以像定义函数一样传入一些必要或非必要参数,如下例:

无缺省值的参数,必须在初始化class的实例时定义:

object main{
def main(args: Array[String]): Unit = {
//初始化类的实例时传入无缺省必要参数
val demoFather = new Father(Firstname = "Zhang")
//调用类中的introduce方法
demoFather.introduce
}
} class Father(Firstname:String){
val Lastname:String="feifei"
def introduce: Unit ={
println(this.Firstname+Lastname)
}
}

有缺省值的参数:

object main{
def main(args: Array[String]): Unit = {
//调用类中的introduce方法,这里的参数有缺省值可以不传入
val demoFather = new Father()
demoFather.introduce
}
}
class Father(Firstname:String="Wang"){
val Lastname:String="feifei"
def introduce: Unit ={
println(this.Firstname+Lastname)
}
}

2.2 特质与混入

  Scala中的特质用trait关键字来定义,混入用extends的方式,通过with以混入多个特质,下面是一个简单的演示:

object main{
def main(args: Array[String]): Unit = {
//调用混入后的方法
val vehicle = new Vehicle
vehicle.brand
vehicle.Amount
vehicle.amount
}
} //特质1
trait Car{
def brand: Unit ={
println("本田")
}
} //特质2
trait Wheel{
def amount: Unit ={
println("4个轮子")
}
} //特质3
trait Glass{
def Amount: Unit ={
println("深灰色的玻璃")
}
} //混入三个特质
class Vehicle extends Car with Wheel with Glass

  以上就是本文的全部内容,若有笔误之处,望指出。

(数据科学学习手札46)Scala中的面向对象的更多相关文章

  1. (数据科学学习手札32)Python中re模块的详细介绍

    一.简介 关于正则表达式,我在前一篇(数据科学学习手札31)中已经做了详细介绍,本篇将对Python中自带模块re的常用功能进行总结: re作为Python中专为正则表达式相关功能做出支持的模块,提供 ...

  2. (数据科学学习手札42)folium进阶内容介绍

    一.简介 在上一篇(数据科学学习手札41)中我们了解了folium的基础内容,实际上folium在地理信息可视化上的真正过人之处在于其绘制图像的高度可定制化上,本文就将基于folium官方文档中的一些 ...

  3. (数据科学学习手札49)Scala中的模式匹配

    一.简介 Scala中的模式匹配类似Java中的switch语句,且更加稳健,本文就将针对Scala中模式匹配的一些基本实例进行介绍: 二.Scala中的模式匹配 2.1 基本格式 Scala中模式匹 ...

  4. (数据科学学习手札44)在Keras中训练多层感知机

    一.简介 Keras是有着自主的一套前端控制语法,后端基于tensorflow和theano的深度学习框架,因为其搭建神经网络简单快捷明了的语法风格,可以帮助使用者更快捷的搭建自己的神经网络,堪称深度 ...

  5. (数据科学学习手札69)详解pandas中的map、apply、applymap、groupby、agg

    *从本篇开始所有文章的数据和代码都已上传至我的github仓库:https://github.com/CNFeffery/DataScienceStudyNotes 一.简介 pandas提供了很多方 ...

  6. (数据科学学习手札55)利用ggthemr来美化ggplot2图像

    一.简介 R中的ggplot2是一个非常强大灵活的数据可视化包,熟悉其绘图规则后便可以自由地生成各种可视化图像,但其默认的色彩和样式在很多时候难免有些过于朴素,本文将要介绍的ggthemr包专门针对原 ...

  7. (数据科学学习手札50)基于Python的网络数据采集-selenium篇(上)

    一.简介 接着几个月之前的(数据科学学习手札31)基于Python的网络数据采集(初级篇),在那篇文章中,我们介绍了关于网络爬虫的基础知识(基本的请求库,基本的解析库,CSS,正则表达式等),在那篇文 ...

  8. (数据科学学习手札47)基于Python的网络数据采集实战(2)

    一.简介 马上大四了,最近在暑期实习,在数据挖掘的主业之外,也帮助同事做了很多网络数据采集的内容,接下来的数篇文章就将一一罗列出来,来续写几个月前开的这个网络数据采集实战的坑. 二.马蜂窝评论数据采集 ...

  9. (数据科学学习手札40)tensorflow实现LSTM时间序列预测

    一.简介 上一篇中我们较为详细地铺垫了关于RNN及其变种LSTM的一些基本知识,也提到了LSTM在时间序列预测上优越的性能,本篇就将对如何利用tensorflow,在实际时间序列预测任务中搭建模型来完 ...

随机推荐

  1. February 2 2017 Week 5 Thursday

    Only do what your heart tells you. 随心而行. My heart tells me that I should leave here and go back to X ...

  2. Spring Framework5.0 学习(4)—— Bean的命名id和name区别

    Spring中Bean的命名 1.每个Bean可以有一个id属性,并可以根据该id在IoC容器中查找该Bean,该id属性值必须在IoC容器中唯一: 2.可以不指定id属性,只指定全限定类名,如: & ...

  3. Intellij IDEA 格式化代码

  4. JavaScript 初学备忘录

    JavaScript 是脚本语言 JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编程代码. JavaScript 插入 HTML 页面后,可由所有的现 ...

  5. JSON解析问题

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/quanqinayng/article/details/25121955 这是data.chatFil ...

  6. 用SQL实现的BASE64加密及解密函数(SQL2005以上有效)

    CREATE FUNCTION [dbo].[f_base64_encode] (@bin varbinary(max)) returns varchar(max) as begin return c ...

  7. BZOJ1996:[HNOI2010]CHORUS 合唱队(区间DP)

    Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Solution 辣鸡guide真难用 ...

  8. BZOJ 2818 GCD 【欧拉函数 || 莫比乌斯反演】

    传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=2818 2818: Gcd Time Limit: 10 Sec  Memory Limit ...

  9. Windows平台JxCore打包

    1.下载JxCore https://raw.githubusercontent.com/jxcore/jxcore-release/master/0311/jx_win64v8.zip 2.解压并配 ...

  10. 面试准备——(二)专业知识(1)Linux

    面试的问题: 腾讯: 1. 查看进程的命令 美团: 1. 常用的命令——美团/滴滴 2. 如何在性能测试的时候查看进程 3. kill -9/-15区别 滴滴: 1.如何找到一个特定文件 2. 如何替 ...