一天学完spark的Scala基础语法教程十、类和对象(idea版本)

简介: 一天学完spark的Scala基础语法教程十、类和对象(idea版本)

创建测试类【day1/demo10.scalc】,类型为【Object】

image.png

image.png

Scala 类和对象

类是对象的抽象,而对象是类的具体实例。类是抽象的,不占用内存,而对象是具体的,占用存储空间。类是用于创建对象的蓝图,它是一个定义包括在特定类型的对象中的方法和变量的软件模板。

示例

package day1
object demo10 {
  def main(args: Array[String]): Unit = {
    var de=new demo10_class();//通过new创建对象
    println(de.toMax(5,6))
  }
}
class demo10_class{
  def toMax(x:Int,y:Int):Int={
    if(x>y){
      return x;
    }
    return y;
  }
}

image.png

【class】类关键字

class关键字修饰的是类,只有通过class修饰的类才能被【new】创建,这里就不能再次创建【object】类型了,可以自行测试,会报错的。


new,在内存中创建出一个地址,存储了这个类的信息。


var de=new demo10_class();//通过new创建对象

对象

对象就是一个特指,这个对象有其自身的【属性】以及【方法】。


例如:单独说公交车,它是一个类,但是你要说,石家庄车牌为冀A *****的1路公交车,那么它就是对象,有具体的针对性。


Scala 继承

Scala继承一个基类跟Java很相似, 但我们需要注意以下几点:


1、重写一个非抽象方法必须使用override修饰符。

2、只有主构造函数才可以往基类的构造函数里写参数。

3、在子类中重写超类的抽象方法时,你不需要使用override关键字。

接下来让我们来看个实例:


package day1
object demo10 extends demo10_class {
  def main(args: Array[String]): Unit = {
    //由于继承了【demo10_class】类,故而可以直接使用
    println(toMax(51,6))
  }
}
class demo10_class{
  def toMax(x:Int,y:Int):Int={
    if(x>y){
      return x;
    }
    return y;
  }
}


image.png


重写

这里我就留了一个简单的实例重写,继承了父类,所以可以直接用super


package day1
object demo10 extends demo10_class {
  //重写
  override def toMax(x: Int, y: Int): Int = super.toMax(x, y)
  def main(args: Array[String]): Unit = {
    //由于继承了【demo10_class】类,故而可以直接使用
    println(toMax(51,66))
  }
}
class demo10_class{
  def toMax(x:Int,y:Int):Int={
    if(x>y){
      return x;
    }
    return y;
  }
}


image.png


功能依然都是正常可用的。


相关文章
|
22天前
|
分布式计算 大数据 Java
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
34 5
|
22天前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
44 3
|
22天前
|
消息中间件 分布式计算 NoSQL
大数据-104 Spark Streaming Kafka Offset Scala实现Redis管理Offset并更新
大数据-104 Spark Streaming Kafka Offset Scala实现Redis管理Offset并更新
31 0
|
22天前
|
消息中间件 存储 分布式计算
大数据-103 Spark Streaming Kafka Offset管理详解 Scala自定义Offset
大数据-103 Spark Streaming Kafka Offset管理详解 Scala自定义Offset
59 0
|
22天前
|
分布式计算 大数据 Java
大数据-86 Spark 集群 WordCount 用 Scala & Java 调用Spark 编译并打包上传运行 梦开始的地方
大数据-86 Spark 集群 WordCount 用 Scala & Java 调用Spark 编译并打包上传运行 梦开始的地方
15 1
大数据-86 Spark 集群 WordCount 用 Scala & Java 调用Spark 编译并打包上传运行 梦开始的地方
|
27天前
|
应用服务中间件 Windows
震惊!idea 2021 社区版手把手安装,超详细过程,新手一看就会 如何安装低版本的IDEA? IDEA安装过程中版本冲突怎么办 idea最新版安装!
本文提供了一个详细的指南,用于安装2021年社区版的IntelliJ IDEA,包括如何处理版本冲突和完成安装过程。
145 2
震惊!idea 2021 社区版手把手安装,超详细过程,新手一看就会 如何安装低版本的IDEA? IDEA安装过程中版本冲突怎么办 idea最新版安装!
|
18天前
|
Java Maven Spring
springboot学习一:idea社区版本创建springboot项目的三种方式(第三种为主)
这篇文章介绍了在IntelliJ IDEA社区版中创建Spring Boot项目的三种方法,特别强调了第三种方法的详细步骤。
67 0
springboot学习一:idea社区版本创建springboot项目的三种方式(第三种为主)
|
27天前
|
Java 关系型数据库 开发工具
idea创建不了spring2.X版本,无法使用JDK8,最低支持JDK17 , 如何用idea创建spring2.X版本,使用JDK8解决方案
本文提供了解决方案,如何在IDEA中创建Spring 2.X版本的项目并使用JDK8,尽管Spring 2.X已停止维护且IDEA不再直接支持,通过修改pom.xml或使用阿里云的国内源来创建项目。
50 0
idea创建不了spring2.X版本,无法使用JDK8,最低支持JDK17 , 如何用idea创建spring2.X版本,使用JDK8解决方案
|
22天前
|
SQL 分布式计算 Java
大数据-96 Spark 集群 SparkSQL Scala编写SQL操作SparkSQL的数据源:JSON、CSV、JDBC、Hive
大数据-96 Spark 集群 SparkSQL Scala编写SQL操作SparkSQL的数据源:JSON、CSV、JDBC、Hive
23 0
|
22天前
|
缓存 分布式计算 大数据
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(一)
大数据-90 Spark 集群 RDD 编程-高阶 RDD容错机制、RDD的分区、自定义分区器(Scala编写)、RDD创建方式(一)
30 0