abstract
이해: abstract 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
方法调用;
Hibernate
中模板程序;
Spring
中JDBCTemlate
、HibernateTemplate
abstract
사용 가능 클래스와 메소드. 🎜🎜추상
을 사용하여 변수, 코드 블록 및 생성자를 수정할 수 없습니다. 🎜🎜추상
을 사용하여 비공개 메서드, 정적 메서드, final
메서드 및 final
클래스를 수정할 수 없습니다. 🎜🎜🎜🎜3. 수정된 클래스 - 추상 클래스🎜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); } } }
추상
으로 수정해야 합니다. 🎜🎜🎜🎜5. 코드 데모🎜rrreee🎜6. 고전적인 질문🎜rrreee🎜7. 추상 클래스의 익명 하위 클래스🎜rrreee🎜8. 응용 프로그램 - 템플릿 메서드 디자인 패턴(TemplateMethod)🎜🎜추상 클래스는 일종의 템플릿을 구현합니다. 패턴 설계에서 추상 클래스는 여러 하위 클래스에 대한 공통 템플릿 역할을 합니다. 하위 클래스는 추상 클래스를 기반으로 확장 및 변환되지만 하위 클래스는 일반적으로 추상 클래스의 동작을 유지합니다. 🎜🎜기능 구현이 확실한 부분은 구현이 불확실한 부분이 있습니다. 이때 불확실한 부분을 노출하고 서브클래스에서 구현하도록 할 수 있습니다. 🎜🎜즉, 소프트웨어 개발에서 알고리즘을 구현할 때 전반적인 단계는 매우 고정적이고 공통적이며 이러한 단계는 이미 상위 클래스에 작성되어 있습니다. 그러나 일부 부분은 휘발성이며 휘발성 부분은 다른 하위 클래스로 추상화되고 구현될 수 있습니다. 이것은 템플릿 패턴입니다. 🎜🎜템플릿 메소드 디자인 패턴은 프로그래밍에서 자주 사용되는 패턴입니다. 모든 프레임워크와 클래스 라이브러리에 그림자가 있습니다. 예를 들어 일반적인 것들은 다음과 같습니다: 🎜🎜 데이터베이스 액세스 캡슐화 🎜Junit
단위 테스트; 🎜🎜JavaWeb
의 Servlet
에서 doGet/doPost
메서드 호출 정보 🎜🎜Hibernate
템플릿 프로그램 🎜🎜Spring
JDBCTemlate
, HibernateTemplate
등 🎜🎜🎜rrreee위 내용은 Java 키워드 요약을 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!