2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Warum gibt es eine Schnittstelle?
Wie wir alle wissen, besteht die Vererbung darin, die gemeinsamen Abstraktionen in der Unterklasse in die übergeordnete Klasse zu extrahieren und zu erhaltenGemeinsamkeit des gesamten SystemsUm Code zu sparen, gibt es jedoch auch eine Situation: Die meisten Unterklassen haben eine gewisse Gemeinsamkeit, aber nur wenige Unterklassen verfügen nicht über diese Funktion. Wenn diese Gemeinsamkeit dann in die übergeordnete Klasse geschrieben wird, wird sie vererbt. Dies ist unzumutbar diese wenigen Unterkategorien.
Zum Beispiel: Katzen und Hunde können schwimmen, Kaninchen jedoch nicht. Wenn zu diesem Zeitpunkt die Methode „Schwimmen“ in der übergeordneten Klasse definiert ist, ist es für Kaninchen nicht sinnvoll, ihre eigenen Schwimmmethoden zu erben Es kann daher vorkommen, dass das Schreibformat und die Benennung der beiden Methoden inkonsistent sind. Daher müssen wir ein neues Konzept definieren, um die Schreibspezifikationen der „schwimmenden“ Methoden in diesen beiden Unterklassen einzuschränken.An dieser Stelle können wir ein „Schwimmen“ definierenSchnittstelleDefinieren Sie die abstrakte Methode swim () in der Schnittstelle und lassen Sie dann Katzen und Hunde eine Verbindung zu dieser Schnittstelle herstellen, um dies sicherzustellenCode-Vereinheitlichung。
Zusammenfassend lässt sich sagen, dass die Schnittstelle eine istRegelWenn wir Regeln für mehrere Klassen gleichzeitig definieren müssen, müssen wir sie verwendenSchnittstelle。
Die Schnittstelle stellt keine Art von Sache dar, sie repräsentiert sieeine Regel, sodass Schnittstellen als Parameter an Methoden übergeben werden können.
„Ob es sich um einen Lastwagen, ein Dreirad oder Arbeitskräfte handelt, solange es sich bewegen kann, wird es nützlich sein.“
搬家(车的对象);
搬家(搬家公司);
public interface 运输 {
...
}
public void 搬家(运输的接口 c) {
...
}
public interface 接口名 {}
public class 类名 implements 接口名 {}
public class 类名 implements 接口名1 , 接口名2 {}
public class 类名 extends 父类 implements 接口名1 , 接口名2 {}
üben:Schreiben Sie Standard-Javabean-Klassen mit Schnittstellen und abstrakten Klassen.
青蛙 属性:名字,年龄 行为:吃虫子,蛙泳
狗 属性:名字,年龄 行为:吃骨头,狗刨
兔子 属性:名字,年龄 行为:吃胡萝卜
Schreiben Sie zuerst die übergeordnete Klasse. Da die drei Unterklassen unterschiedliche Dinge essen, können Sie eat() als abstrakte Methode definieren:
package oopInterface;
public abstract class Animal {
private String name;
private int age;
public Animal() {
}
public Animal(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public abstract void eat();
}
Schreibschnittstelle Schwimmen:
package oopInterface;
public interface Swim {
public abstract void swim();
}
Achten Sie beim Schreiben einer Froschklasse darauf, die übergeordnete Klasse zu erben, die abstrakte Methode der übergeordneten Klasse neu zu schreiben und die Schwimmschnittstelle zu implementieren:
package oopInterface;
public class Frog extends Animal implements Swim {
public Frog() {
super();
}
public Frog(String name, int age) {
super(name, age);
}
@Override
public void swim() {
System.out.println("青蛙在蛙泳。");
}
@Override
public void eat() {
System.out.println("青蛙在吃虫子。");
}
}
Achten Sie beim Schreiben einer Hundeklasse darauf, die übergeordnete Klasse zu erben und die abstrakte Methode der übergeordneten Klasse neu zu schreiben, um die Schwimmschnittstelle zu implementieren:
package oopInterface;
public class Dog extends Animal implements Swim {
public Dog(){
super();
}
public Dog(String name, int age) {
super(name,age);
}
@Override
public void swim() {
System.out.println("狗在狗刨。");
}
@Override
public void eat() {
System.out.println("狗在吃骨头。");
}
}
Beachten Sie beim Schreiben einer Kaninchenklasse, dass Sie nur die übergeordnete Klasse erben und die abstrakte Methode überschreiben müssen und die Schwimmschnittstelle nicht implementieren müssen (Sie können nicht schwimmen):
package oopInterface;
public class Rabbit extends Animal {
public Rabbit() {
}
public Rabbit(String name, int age) {
super(name, age);
}
@Override
public void eat() {
System.out.println("兔子在吃胡萝卜。");
}
}
Schreiben Sie Testklassen.
package oopInterface;
public class Test {
public static void main(String[] args) {
Frog f = new Frog("小绿",23);
f.eat();
f.swim();
System.out.println(f.getName() + ", " + f.getAge());
Dog d = new Dog("大D", 24);
d.eat();
d.swim();
System.out.println(d.getName() + ", " + d.getAge());
Rabbit r = new Rabbit("兔子", 30);
r.eat();
System.out.println(r.getName() + ", " + r.getAge());
}
}
Beachten:
1. Wenn eine Klasse eine Schnittstelle implementiert, muss sie entweder alle abstrakten Methoden in der Schnittstelle implementieren oder die Klasse selbst ist ebenfalls eine abstrakte Klasse.
2. Eine Klasse kann mehrere Schnittstellen implementieren, wenn sie mehrere Schnittstellen implementiertalleAlle in der Schnittstelle zu implementierenden abstrakten Methoden werden implementiert.
3. Schnittstellen können von mehreren Schnittstellen geerbt werden. Wenn eine Unterschnittstelle mehrere Schnittstellen erbt und dann von einer Implementierungsklasse implementiert wird, muss die Implementierungsklasse die Unterschnittstelle und alle ihre übergeordneten Schnittstellen kombinieren.alleAlle abstrakten Methoden sind implementiert.
üben:Schreiben Sie Standard-Javabean-Klassen mit Schnittstellen und abstrakten Klassen.
乒乓球运动员:姓名,年龄,学打乒乓球,说英语
篮球运动员:姓名,年龄,学打篮球
乒乓球教练:姓名,年龄,教打乒乓球,说英语
篮球教练:姓名,年龄,教打篮球
//Person类
package oopInterExp;
//因为直接创建顶层父类人的对象是没有意义的
//所以将其写为抽象类
public abstract class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public Person() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
//Sporter类继承Person
package oopInterExp;
public abstract class Sporter extends Person {
public Sporter(String name, int age) {
super(name, age);
}
public Sporter() {
}
public abstract void learn();
}
//Coach类继承Person
package oopInterExp;
public abstract class Coach extends Person {
public Coach() {
}
public Coach(String name, int age) {
super(name, age);
}
public abstract void teach();
}
//SpeakEnglish接口
package oopInterExp;
public interface SpeakEnglishInter {
public abstract void speakEnglish();
}
//PingPongSporter继承Sporter,实现SpeakEnglish
package oopInterExp;
public class PingPongSporter extends Sporter implements SpeakEnglishInter {
public PingPongSporter(String name, int age) {
super(name, age);
}
public PingPongSporter() {
}
@Override
public void learn() {
System.out.println("学习乒乓球。");
}
@Override
public void speakEnglish() {
System.out.println("乒乓球运动员在说英语。");
}
}
//PingPongCoach继承Coach,实现SpeakEnglish
package oopInterExp;
public class PingPongCoach extends Coach implements SpeakEnglishInter {
public PingPongCoach() {
}
public PingPongCoach(String name, int age) {
super(name, age);
}
@Override
public void teach() {
System.out.println("教乒乓球。");
}
@Override
public void speakEnglish() {
System.out.println("乒乓球教练在说英语。");
}
}
//BasketballSporter继承Sporter
package oopInterExp;
public class BasketballSporter extends Sporter {
public BasketballSporter(String name, int age) {
super(name, age);
}
public BasketballSporter() {
}
public void learn() {
System.out.println("学篮球。");
}
}
//BasketballCoach继承Coach
package oopInterExp;
public class BasketballCoach extends Coach {
public BasketballCoach() {
}
public BasketballCoach(String name, int age) {
super(name, age);
}
public void teach() {
System.out.println("教篮球。");
}
}
Vor JDK7 konnten in Schnittstellen nur abstrakte Methoden definiert werden.
Die neue Funktion von JDK8 ist: Methoden mit Methodenkörpern können in der Schnittstelle definiert werden (können definiert werden).StandardMethode bzwstatischMethode).
Das neue Feature von JDK9 ist: Es kann in der Schnittstelle definiert werdenPrivatMethode.
Methoden mit Methodenkörpern werden in der Schnittstelle definiert, hauptsächlich fürSchnittstellen-UpgradeDa die Schnittstelle nicht unveränderlich sein kann, müssen zum Aktualisieren neue Methoden hinzugefügt werden. Wenn es sich bei diesen Methoden um abstrakte Methoden handelt, müssen diese Methoden zu diesem Zeitpunkt gleichzeitig in der Implementierungsklasse implementiert werden, was sehr problematisch ist nicht einfach zu synchronisieren; wenn das Upgrade eine Methode mit einem Methodenkörper verwendet, muss die Implementierungsklasse nicht zusätzlich geändert werden. Wenn eine Änderung erforderlich ist, kann sie auch durch Umschreiben geändert werden.
Schnittstelle Inter1:
package oopInterface5;
public interface Inter1 {
public abstract void method();
public default void default_method() {
System.out.println("Inter1接口中的默认方法");
}
}
Schnittstelle Inter2:
package oopInterface5;
public interface Inter2 {
public default void default_method() {
System.out.println("Inter2接口中的默认方法");
}
}
Die beiden Standardmethoden haben den gleichen Namen. Wenn die Implementierungsklasse diese beiden Schnittstellen gleichzeitig implementiert, muss diese Standardmethode neu geschrieben werden!
package oopInterface5;
public class InterImpl implements Inter1, Inter2 {
@Override
public void method() {
System.out.println("抽象方法的实现");
}
@Override
public void default_method() {
System.out.println("重写接口中的默认方法");
}
}
Testklasse:
package oopInterface5;
public class Test {
public static void main(String[] args) {
InterImpl ii = new InterImpl();
ii.method(); //抽象方法的实现
ii.default_method(); //重写接口中的默认方法
}
}
Mit JDK8 und höher können statische Methoden in Schnittstellen definiert werden, die mit statischen Methoden geändert werden müssen.
in der Schnittstellestatische MethodeDas Definitionsformat ist:
Was Sie bei statischen Methoden in Schnittstellen beachten sollten:
Schreiben Sie eine Schnittstelle:
package oopInterface6;
public interface Inter {
public abstract void method();
public static void static_method() {
System.out.println("接口中的静态方法");
}
}
Schreiben Sie eine Implementierungsklasse. Es gibt auch eine statische Methode in der Klasse mit demselben Namen wie die Methode in der Schnittstelle, diese wird jedoch nicht überschrieben, da statische Methoden nicht überschrieben werden können:
package oopInterface6;
public class InteImpl implements Inter {
@Override
public void method() {
System.out.println("重写接口中的抽象方法");
}
//这不叫重写
public static void static_method() {
System.out.println("我不是重写的Inter接口中的静态方法");
}
}
Tatsächlich handelt es sich jedoch um unterschiedliche Methoden.
package oopInterface6;
public class Test {
public static void main(String[] args) {
InteImpl ii = new InteImpl();
ii.method(); //重写接口中的抽象方法
Inter.static_method(); //调用接口中的静态方法
InteImpl.static_method(); //调用实现类中的一个同名的静态方法
}
}
package oopInterface7;
public interface InterA {
public default void show1() {
System.out.println("show1开始执行");
show3();
}
public default void show2() {
System.out.println("show2开始执行");
show3();
}
//普通的私有方法,给默认方法服务的
private void show3() {
System.out.println("记录程序在运行过程中的各种细节,这里有100行代码。");
}
}
package oopInterface7;
public interface InterB {
public static void show1() {
System.out.println("show1开始执行");
show3();
}
public static void show2() {
System.out.println("show2开始执行");
show3();
}
//普通的私有方法,给静态方法服务的
private static void show3() {
System.out.println("记录程序在运行过程中的各种细节,这里有100行代码。");
}
}
1. Die Schnittstelle stellt Regeln dar und ist eine Abstraktion des Verhaltens. Wenn Sie möchten, dass eine Klasse ein Verhalten hat, lassen Sie die Klasse einfach die entsprechende Schnittstelle implementieren.
2. Wenn der Parameter einer Methode eine Schnittstelle ist, kann die Schnittstelle übergeben werdenAlle Objekte der ImplementierungsklasseDieser Ansatz wird als Schnittstellenpolymorphismus bezeichnet.
Adapter können verwendet werden, um Code zu vereinfachen und die Unannehmlichkeiten zu vermeiden, die entstehen, wenn die Schnittstelle zu viele abstrakte Methoden enthält und wir nur einen Teil davon verwenden müssen.
Die Schreibschritte sind im Allgemeinen:
1. Schreiben Sie die Zwischenklasse XXXAdapter, um die entsprechende Schnittstelle zu implementieren.
2. Implementieren Sie leere Implementierungen abstrakter Methoden in der Schnittstelle.
3. Lassen Sie die reale Implementierungsklasse die Zwischenklasse erben und schreiben Sie die erforderlichen Methoden neu.
4. Um zu verhindern, dass andere Klassen Objekte der Adapterklasse erstellen, wird die Zwischenadapterklasse mit Abstract dekoriert.
Schnittstelle:
package AdapterDesignPattern;
public interface Inter {
public abstract void method1();
public abstract void method2();
public abstract void method3();
public abstract void method4();
public abstract void method5();
}
Adapterklasse:
package AdapterDesignPattern;
public abstract class InterAdapter implements Inter {
@Override
public void method1() {
}
@Override
public void method2() {
}
@Override
public void method3() {
}
@Override
public void method4() {
}
@Override
public void method5() {
}
}
Implementierungsklasse:
package AdapterDesignPattern;
public class InterImpl extends InterAdapter {
//我需要用到哪个方法,就重写哪个方法就可以了
@Override
public void method5() {
System.out.println("只要用第五个方法");
}
}