应用对象、抽象类、特质、继承、实现、重写

本文深入探讨Scala中的抽象类、特质、继承、实现与重写概念,通过具体实例展示如何使用这些特性构建复杂对象,如实现一个拥有飞行能力的人类对象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2018-12-04 15:33:05

应用程序对象
class AppTest {

}
object AppTest extends App{ //继承App类,程序可以直接执行,无需main函数
  val str = "yaoyao"
  println(s"$str is my right girl")
}

 抽象类、特质、继承、实现、重写

object ClassDemo {
  def main(args: Array[String]): Unit = {
    val human = new Human

    println(human.hight)
    println(human.name)


  }
}

/**
  * 特质
  */
trait Flyable{
  // 声明一个有值的字段
  val distance: Int = 1000
  // 声明一个没有值的字段
  val hight: Int
  // 声明一个有方法体的方法
  def fly: String = {
    "I can fly"
  }
  // 声明一个没有方法体的方法
  def fight: String
}

/**
  * 抽象类
  */
abstract class Animal{
  // 声明一个有值的字段
  val age  = 3
  // 声明一个没有值的字段
  val name: String
  // 声明一个有方法体的方法
  def climb: String = {
    "I can climb"
  }
  // 声明一个没有方法体的方法
  def run: String
}

// 在没有继承父类的情况下,如果需要是一个特质,此时需要用extends关键字,而不是with
class Human extends Animal with Flyable{ //extends继承,with实现
  override val name = "tom" //override重写
  override val age: Int = 6

  override def run = "I can run"

  override def climb: String = "I can not climb"

  override val hight = 2

  override def fight = "fight with 棒子"

  override def fly: String = "I can not fly"

}

  

转载于:https://www.cnblogs.com/wanfeng1937/p/10064459.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值