zoukankan      html  css  js  c++  java
  • Scala面向对象—类详解2(继承相关)

    1、单例类

    package com.zzzy
    
    class AAA {//单例
      /*//java  思路--私有化构造方法,提供公开的getAAA   行不通
      private  def this(){
        this()
      }
    
      def  getAAA():AAA={
        val aaa = new AAA()
        return aaa
      }
    */
    }
    package com.zzzy
    //单例类
    
    //伴生类
    class BBB private(){//1私有化构造方法
    
    
    }
    
    //伴生对象
    object BBB{
    
      //不写apply
      private val bbb=new BBB()//2创建一个私有对象
      def getBBB:BBB={//3提供了一个公开的get方法
        bbb
      }
    
    }
    package com.zzzy
    object test {
      def main(args: Array[String]): Unit = {
    
        val b1 = BBB.getBBB
        val b2=BBB.getBBB
        println(b1==b2)//true
    
      }
    
    }

    2、object的继承和App

    package com.zzzzy
    
    abstract class Register {//定义一个抽象类
      //抽象方法(没有方法体,只有方法定义)
      def  regist(name:String)
    
      def unregist(name:String)
    
    }
    package com.zzzzy
    //实现用extends
    object User1 extends Register {
      override def regist(name: String): Unit = {
        println(name+"注册了")
    
      }
    
      override def unregist(name: String): Unit = {
        println(name+"注销了")
    
      }
    }
    package com.zzzzy
    
    class User2(n:String) extends Register {//主构造方法
      override def regist(name: String): Unit = {
        println(name+"注册"+n)
    
      }
    
      override def unregist(name: String): Unit ={
        println(name+"注销"+n)
      }
    }
    package com.zzzzy
    
    object test extends App {//1如果一个对象继承App可以不需要main方法直接运行
      /*def main(args: Array[String]): Unit = {
        println("aaa")
      }*/
    
      println("bbb")
    
      //2让一个object实现一个抽象类用关键字extends   重写未实现的方法
      User1.regist("小敏")
      User1.unregist("笑笑")
    
      //3让一个class实现一个抽象类用关键字extends   重写未实现的方法可以有构造方法
      new User2("白白").regist("lili")
      new User2("白白").unregist("jack")
    
    }

    3、类的继承

    package com.zzzzzy
    
    class Person {
      var name:String=_//必须给类型,无法推断
      var age:Int=_
      private var num=99
      def show(): Unit ={
        print("父类的方法")
      }
    
    }
    package com.zzzzzy
    class Student extends Person {
      //不能重写被final修饰的方法
    
    
      var sex:Char='男'
    
      override def show(): Unit = {
        println("重写父类的方法show")
      }
    
      def speak(): Unit ={
        //调用了父类的属性 实测在运行中无法使用
        /*println(super.age)
        print(super.name)*/
          //私有属性num无法通过super找到
    
    
        super.show()//父类的方法
        show()//子类重写的
      }
    
    
    
    }
    package com.zzzzzy
    
    object test extends App {
      val stu = new Student
      stu.speak()
    
    
    //多态的向上转型
      var s:Person=new Student()
      //还能得到子类特有的方法和属性吗?不能
      s.show()//调用的为子类重写的方法
      println(s.name)//null
      println(s.age)
      
    
    }

    4、类型检查和类型转换

    package com.zzzzzzy
    
    class Person(name:String,age:Int){
      var name1="小明"
      var age1=50
      def show(): Unit ={
        println(name+"	"+age)
      }
    
    
    
    }
    package com.zzzzzzy
    
    //在一个scala文件中可以定义n个类  写在一行必须写;  大括号可以省略
    class Emp extends Person("李四",40)
    class Student extends Person("张三",30)
    package com.zzzzzzy
    
    object test extends App {
       val em = new Emp
      em.show()
       val stu = new Student
      stu.show()
      
      println("---------------------")
      //判断某个对象是否是某个类型
     val ss= new Student()
      //继承关系上  is a
      println(ss.isInstanceOf[Person])
    
      //转换--向上转型
      val pp: Person = ss.asInstanceOf[Person]
      pp.show()
    
    }

    5、protected关键字

    package com.yz.extendz
    
    class Animal {//父类     A和B都不是Animal的子类。那么属性的可使用情况如下
      val a=100           //A类可用           //B类可用
      protected  val b=200
      protected [this] val c=300
      protected [extendz] val d=400//yz为包名     //A类可用
    
    
      //这里四个属性,只要是Animal的子类都可以使用,无论在不在同一个包中
    
    
    
    }
    package com.yz.extendz
    
    class Cat extends Animal{
      val y=888
      def show: Unit ={
        println(s"$a-------$b------$c---------$d")
      }
    
    }
    package com.yz.extendz
    
    class Dog extends Animal {
      val x=999
      def show: Unit ={
        println(s"$a-------$b------$c---------$d")
      }
    
    }
    package com.yz.extendz
    
    class A {
      def show: Unit ={
        val animal = new Animal
        println(animal.a)
        println(animal.d)
      }
    
    
    }
    package com.yz2
    
    import com.yz.extendz.Animal
    
    class B {
      def show: Unit ={
        val animal = new Animal
        println(animal.a)
      }
    
    }

    6、匿名子类

    package com.yz3
    
    class Person {
      def aaa="中国"
    
    }
    package com.yz3
    
    object test  extends App {
    
      val pp= new Person {
        override def aaa: String = "新中国"
      }
     //这个过程中产生了一个匿名子类【发生重写,子类重写父类方法但是又没有显示的定义处理----匿名】
    
       val result = pp.aaa
      println(result)
    
    
      //定义方法
      println("-------------------")
      def show(p:Person): Unit ={
        println(p.aaa)
      }
    
      //调用
      show(new Person)
    }

    7、抽象

    package com.yz4
    
    abstract class Animal {//可以用于抽象或非抽象方法   拥有抽象字段/非抽象字段
    //抽象字段(没有初始值)
      val count:Int
      //非抽象字段
      val num=100
    
    
      //抽象方法
      def aaa:String
      //非抽象方法
      def bbb: Int ={
        10
      }
    
    }
    package com.yz4
    
    class Cat extends Animal {
      //重写抽象方法
      override def aaa: String = {"你好"}
    
      override val count: Int = 666
    }
    package com.yz4
    
    object test extends App {
     val cat = new Cat
       val aaa: String = cat.aaa
       val bbb: Int = cat.bbb
       println(aaa+bbb)
    
    }

    8、特质(java接口)

    package com.yz5
    
    trait Log {
      //非抽象方法   抽象时super调用时会出错
      def  showa:String={
    "原始的"
      }
    
    }
    package com.yz5
    
    trait ALog extends Log {
      override def showa: String = {
        super.showa
        println("ALog重写的方法")
    
        "ALog"
      }
    
    }
    package com.yz5
    
    trait BLog extends Log {
      override def showa: String = {
        println("BLog重写的方法")
        super.showa
    
        "BLog"
      }
    
    }
    package com.yz5
    
    class CCC extends ALog with BLog {//继承两个特质
    
      //showa()//默认应该调用最右边的特质中的同名方法【发生同名,以右边为主】
      override def showa: String = {
        super.showa
      }
    
    }
    package com.yz5
    object test extends App {
       val ccc = new CCC
                //条件:ALog和BLog重写方法中调用了super.showa
      ccc.showa//默认把所有的都运行出来(ALog和BLog中的都运行了)没办法只运行左边的
    
    }
  • 相关阅读:
    有多少程序员超过四十岁呢?
    乔布斯的演讲技巧:教你站在讲台上怎样化腐朽为神奇
    想要好看的WORDPRESS模板
    多些时间能少写些代码
    java播放au音频程序
    明星软件工程师的10种特质
    中国互联网创业的四个机遇
    Android环境搭建
    想写代码?离开你的电脑吧!
    深讨Java SE 6 在 HTTP 方面的新特性(NTLM)
  • 原文地址:https://www.cnblogs.com/qfdy123/p/11431772.html
Copyright © 2011-2022 走看看