abstract
:抽象的
abstract
#可以用來修飾類別、方法。
不能用abstract
修飾變數、程式碼區塊、建構器。
不能用abstract
修飾私有方法、靜態方法、final
的方法、final
的類別。
#抽象類別中一定有建構器,以便子類別實例化時呼叫(涉及:子類別物件實例化的全過程)。
開發中,都會提供抽象類別的子類,讓子類別物件實例化,完成相關的操作。
抽象類別不能被實例化。抽象類別是用來被繼承的,抽象類別的子類別必須重寫父類別的抽象方法,並提供方法體。若沒有重寫全部的抽象方法,仍為抽象類別。
抽象方法只有方法的聲明,沒有方法的實作。以分號結束。
public abstract void talk();
含有抽象方法的類別必須宣告為抽象類別。反之,抽象類別中可以沒有抽象方法的。
若子類別重寫了父類別中的所有的抽象方法後,此子類別方可實例化 。
若子類別沒有重寫父類別中的所有的抽象方法,則此子類別也是一個抽象類,需要使用abstract
修飾。
public class AbstractTest { public static void main(String[] args) { //一旦Person类抽象了,就不可实例化 // Person p1 = new Person(); // p1.eat(); } } abstract class Creature{ public abstract void breath(); } abstract class Person extends Creature{ String name; int age; public Person(){ } public Person(String name,int age){ this.name = name; this.age = age; } //不是抽象方法: // public void eat(){ // // } //抽象方法 public abstract void eat(); public void walk(){ System.out.println("人走路"); } } class Student extends Person{ public Student(String name,int age){ super(name,age); } public Student(){ } public void eat(){ System.out.println("学生多吃有营养的食物"); } @Override public void breath() { System.out.println("学生应该呼吸新鲜的没有雾霾的空气"); } }
public class Test1 { public static void main(String args[]) { A a = new B(); a.m1();//B类中定义的m1方法 a.m2();//A类中定义的m2方法 } } abstract class A { abstract void m1(); public void m2() { System.out.println("A类中定义的m2方法"); } } class B extends A { void m1() { System.out.println("B类中定义的m1方法"); } }
public class PersonTest { public static void main(String[] args) { //匿名对象 method(new Student()); //非匿名的类非匿名的对象 Worker worker = new Worker(); method1(worker); //非匿名的类匿名的对象 method1(new Worker()); //创建了一匿名子类的对象:p Person p = new Person(){ @Override public void eat() { System.out.println("吃东西"); } @Override public void breath() { System.out.println("好好呼吸"); } }; method1(p); //创建匿名子类的匿名对象 method1(new Person(){ @Override public void eat() { System.out.println("吃好吃东西"); } @Override public void breath() { System.out.println("好好呼吸新鲜空气"); } }); } public static void method1(Person p){ p.eat(); p.breath(); } public static void method(Student s){ } } class Worker extends Person{ @Override public void eat() { } @Override public void breath() { } }
抽象類別體現的就是一種模板模式的設計,抽象類別作為多個子類別的通用模板,子類別在抽象類別的基礎上進行擴展、改造,但子類別總體上會保留抽象類別的行為方式。
當功能內部一部分實作是確定的,一部分實作是不確定的。這時可以把不確定的部分暴露出去,讓子類別去實作。
換句話說,在軟體開發中實作一個演算法時,整體步驟很固定、通用,這些步驟已經在父類別中寫好了。但是某些部分易變,易變部分可以抽象化出來,供不同子類別實作。這就是一種模板模式。
模板方法設計模式是程式設計中常用得到的模式。各個框架、類別庫中都有他的影子,例如常見的有:
資料庫存取的封裝;
##Junit單元測試;
JavaWeb的
Servlet中關於
doGet/doPost方法呼叫;
abstract class Template { public final void getTime() { long start = System.currentTimeMillis(); code(); long end = System.currentTimeMillis(); System.out.println("执行时间是:" + (end - start)); } public abstract void code(); } class SubTemplate extends Template { public void code() { for (int i = 0; i < 10000; i++) { System.out.println(i); } } }
以上是Java的關鍵字abstract怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!