résumé
: résumé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
peut être utilisé pour modifier les classes et les méthodes. #🎜🎜##🎜🎜#abstract
pour modifier des variables, des blocs de code et des constructeurs. #🎜🎜##🎜🎜#abstract
pour modifier les méthodes privées, les méthodes statiques, les méthodes final
et final classe. #🎜🎜##🎜🎜##🎜🎜##🎜🎜#3. Classe abstraite de classe modifiée#🎜🎜#<ul class=" list-paddingleft-2">
<li>#🎜🎜#La classe abstraite doit être Il existe un constructeur, pratique à appeler lorsque la sous-classe est instanciée (impliquant : l'ensemble du processus d'instanciation de l'objet de sous-classe). #🎜🎜##🎜🎜#</li>
<li>#🎜🎜#Pendant le développement, des sous-classes de classes abstraites seront fournies pour instancier des objets de sous-classe et effectuer les opérations associées. #🎜🎜##🎜🎜#</li>
<li>#🎜🎜#Les classes abstraites ne peuvent pas être instanciées. Les classes abstraites sont destinées à être héritées. Les sous-classes des classes abstraites doivent remplacer les méthodes abstraites de la classe parent et fournir un corps de méthode. Si toutes les méthodes abstraites ne sont pas réécrites, il s’agit toujours d’une classe abstraite. #🎜🎜##🎜🎜##🎜🎜##🎜🎜#4. Méthode modifiée - méthode abstraite #🎜🎜##🎜🎜#La méthode abstraite n'a que la déclaration de la méthode, mais aucune implémentation de la méthode. Terminez par un point-virgule. #🎜🎜#<pre class="brush:java;">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);
}
}
}</pre>#🎜🎜#Les classes contenant des méthodes abstraites doivent être déclarées comme classes abstraites. Au contraire, il ne peut y avoir de méthodes abstraites dans les classes abstraites. #🎜🎜#<ul class=" list-paddingleft-2">
<li>#🎜🎜# Cette sous-classe ne peut être instanciée que si la sous-classe remplace toutes les méthodes abstraites de la classe parent. #🎜🎜##🎜🎜#</li>
<li>#🎜🎜#Si la sous-classe ne remplace pas toutes les méthodes abstraites de la classe parent, alors la sous-classe est également une classe abstraite et doit être modifiée avec <code>abstract code> . #🎜🎜##🎜🎜##🎜🎜##🎜🎜#5. Démonstration de code#🎜🎜#rrreee#🎜🎜#6. Question classique#🎜🎜#rrreee#🎜🎜#7. 🎜🎜#rrreee#🎜🎜#8. Application - Modèle de conception de méthode de modèle (TemplateMethod)#🎜🎜##🎜🎜#Les classes abstraites incarnent la conception d'un modèle de modèle. Les classes abstraites servent de modèles communs pour plusieurs sous-classes s'étendent et. transformation basée sur des classes abstraites, mais les sous-classes conservent généralement le comportement des classes abstraites. #🎜🎜##🎜🎜#Quand une partie de l'implémentation de la fonction est certaine, une partie de l'implémentation est incertaine. À ce stade, vous pouvez exposer les parties incertaines et laisser les sous-classes les implémenter. #🎜🎜##🎜🎜#En d'autres termes, lors de l'implémentation d'un algorithme dans le développement logiciel, les étapes globales sont très fixes et courantes, et ces étapes ont déjà été écrites dans la classe parent. Cependant, certaines parties sont volatiles et peuvent être extraites et implémentées par différentes sous-classes. Ceci est un modèle de modèle. #🎜🎜##🎜🎜#Le modèle de conception de méthode modèle est un modèle souvent utilisé en programmation. Il y a ses ombres dans chaque framework et bibliothèque de classes. Par exemple, les plus courantes sont : #🎜🎜##🎜🎜# Encapsulation de l'accès à la base de données ; #🎜🎜#<ul class=" list-paddingleft-2">
<li>. # 🎜🎜#<code>Junit
test unitaire ; #🎜🎜##🎜🎜#JavaWeb
à propos de doGet/doPostHibernate
programme modèle ; 🎜🎜#JDBCTemlate
, HibernateTemplate
, etc. dans Spring
;Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!