zoukankan      html  css  js  c++  java
  • Java中抽象类

    抽象方法:在类中没有方法体的方法,就是抽象方法。

    抽象类:含有抽象方法的类就叫抽象类。

    抽象类中的抽象方法必须被实现!

    如果一个子类没有实现父类中的抽象方法,则子类也成为了一个抽象类!

    抽象类中的普通方法,可以不必实现。

    1.用abstract来修饰一个类时,这个类叫做抽象类;用abstract来修饰一个方法时,该方法叫做抽象方法。例如 :

     
       抽象类:
    1
    abstract class Animal { //用abstract来定义一个Animal为抽象类}

    抽象方法:

    1
    public abstract void enjoy(); //用abstract来定义一个抽象方法"enjoy"

    含有抽象方法的类必须被声明为抽象类,抽象类必须被继承,抽象方法必须被重写。

    抽象类不能被实例化。

    抽象方法只需声明,而不需实现某些功能。如:

    1
    2
    3
    4
    5
    6
    //抽象方法
    public abstract void enjoy();//这个抽象方法不需要实现功能
    //一般方法
    public void enjoy() {
    System.out.print("叫声"); //而一般的方法有必要实现某些功能
     

    例A:没抽象类的多态程序

     

    例B:抽象类的多态程序

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    abstract class Person {
        public abstract void f();
    }
     
    class Students extends Person {
        public void f() {
            System.out.println("学生类");
        }
    }
    class Teacher extends Person {
        public void f() {
            System.out.println("教师类");
        }
    }
    public class Test3 {
        public static void main(String[] args) {
            Person s = new Students();
            Person t = new Teacher();
            s.f();
            t.f();
        }
    }
  • 相关阅读:
    leetcode练习:26. Remove Duplicates from Sorted Array
    leetcode练习:11. Container With Most Water
    leetcode练习:5. Longest Palindromic Substring
    leetcode练习:2.Add Two Numbers
    算法笔记:分治
    (排序回顾)快速排序
    (排序回顾)归并排序
    leetcode练习:2017/09/21~09/22
    算法笔记:递归&迭代
    在Treeview中节点的data属性中保存记录类型及其消除的办法
  • 原文地址:https://www.cnblogs.com/ylsx/p/15127647.html
Copyright © 2011-2022 走看看