So verwenden Sie private Methoden von Schnittstellen in Java9
Vor Java 8-Versionen
Vor Java 8 schien die Schnittstelle nur zwei Datentypen zuzulassen, einer ist eine Konstante, der andere ist eine öffentliche (öffentliche) virtuelle Methode (abstrakt) und es ist eine virtuelle Methode, aber Es gibt keine Implementierungsmethoden, da diese Methoden von der Klasse implementiert werden müssen. Mit anderen Worten: In Versionen vor Java 8 gibt es keine Methoden mit Standardimplementierung.
Schauen wir uns ein Beispiel an:
public class InterfacePrivateMethodTester { public static void main(String []args) { LogOracle log = new LogOracle(); log.logInfo(""); log.logWarn(""); log.logError(""); log.logFatal(""); LogMySql log1 = new LogMySql(); log1.logInfo(""); log1.logWarn(""); log1.logError(""); log1.logFatal(""); } } final class LogOracle implements Logging { @Override public void logInfo(String message) { getConnection(); System.out.println("Log Message : " + "INFO"); closeConnection(); } @Override public void logWarn(String message) { getConnection(); System.out.println("Log Message : " + "WARN"); closeConnection(); } @Override public void logError(String message) { getConnection(); System.out.println("Log Message : " + "ERROR"); closeConnection(); } @Override public void logFatal(String message) { getConnection(); System.out.println("Log Message : " + "FATAL"); closeConnection(); } @Override public void getConnection() { System.out.println("Open Database connection"); } @Override public void closeConnection() { System.out.println("Close Database connection"); } } final class LogMySql implements Logging { @Override public void logInfo(String message) { getConnection(); System.out.println("Log Message : " + "INFO"); closeConnection(); } @Override public void logWarn(String message) { getConnection(); System.out.println("Log Message : " + "WARN"); closeConnection(); } @Override public void logError(String message) { getConnection(); System.out.println("Log Message : " + "ERROR"); closeConnection(); } @Override public void logFatal(String message) { getConnection(); System.out.println("Log Message : " + "FATAL"); closeConnection(); } @Override public void getConnection() { System.out.println("Open Database connection"); } @Override public void closeConnection() { System.out.println("Close Database connection"); } } interface Logging { String ORACLE = "Oracle_Database"; String MYSQL = "MySql_Database"; void logInfo(String message); void logWarn(String message); void logError(String message); void logFatal(String message); void getConnection(); void closeConnection(); }
Das laufende Ergebnis lautet wie folgt
$ javac InterfacePrivateMethodTester.java && java InterfacePrivateMethodTester
Datenbankverbindung öffnen
Protokollmeldung: INFO
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung : WARN
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: ERROR
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FATAL
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: INFO
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: WARN
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FEHLER
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FATAL
Datenbankverbindung schließen
In diesem Fall hat jeder Protokolltyp seine eigene Implementierung
Was ist die größte Gefahr? Jede Methode muss erneut umgesetzt werden. Ja, jede Methode muss implementiert werden
JDK 8-Version
Und Java 8 hat endlich einige Änderungen vorgenommen. Die Schnittstelle in Java 8 kann die folgenden Arten von Variablen und Methoden haben
2 3, Standardmethode
4, statische Methode
Wir ändern das obige Beispiel und verwenden die Funktionen von Java 8
public class InterfacePrivateMethodTester { public static void main(String []args) { LogOracle log = new LogOracle(); log.logInfo(""); log.logWarn(""); log.logError(""); log.logFatal(""); LogMySql log1 = new LogMySql(); log1.logInfo(""); log1.logWarn(""); log1.logError(""); log1.logFatal(""); } } final class LogOracle implements Logging {} final class LogMySql implements Logging {} interface Logging { String ORACLE = "Oracle_Database"; String MYSQL = "MySql_Database"; default void logInfo(String message) { getConnection(); System.out.println("Log Message : " + "INFO"); closeConnection(); } default void logWarn(String message) { getConnection(); System.out.println("Log Message : " + "WARN"); closeConnection(); } default void logError(String message) { getConnection(); System.out.println("Log Message : " + "ERROR"); closeConnection(); } default void logFatal(String message) { getConnection(); System.out.println("Log Message : " + "FATAL"); closeConnection(); } static void getConnection() { System.out.println("Open Database connection"); } static void closeConnection() { System.out.println("Close Database connection"); } }
Die laufenden Ergebnisse sind wie folgt
$ javac InterfacePrivateMethodTester.java && java InterfacePrivateMethodTesterDatenbankverbindung öffnen
Protokoll Meldung: INFODatenbankverbindung schließenDatenbankverbindung öffnen
Allerdings ist es immer noch sehr verwirrend, das heißt, der Code in jeder Standardmethode muss vollständig sein und andere Standardimplementierungsmethoden können nicht aufgerufen werden
Protokollmeldung: WARN
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FEHLER
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FATAL
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: INFO
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: WARN
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FEHLER
Datenbankverbindung schließen
Datenbankverbindung öffnen
Protokollmeldung: FATAL
Datenbankverbindung schließen
Da Methoden in Java 8-Schnittstellen Standardimplementierungen haben können, d.
Java 9-Versiondefault
public class InterfacePrivateMethodTester { public static void main(String []args) { LogOracle log = new LogOracle(); log.logInfo(""); log.logWarn(""); log.logError(""); log.logFatal(""); LogMySql log1 = new LogMySql(); log1.logInfo(""); log1.logWarn(""); log1.logError(""); log1.logFatal(""); } } final class LogOracle implements Logging {} final class LogMySql implements Logging {} interface Logging { String ORACLE = "Oracle_Database"; String MYSQL = "MySql_Database"; private void log(String message, String prefix) { getConnection(); System.out.println("Log Message : " + prefix); closeConnection(); } default void logInfo(String message) { log(message, "INFO"); } default void logWarn(String message) { log(message, "WARN"); } default void logError(String message) { log(message, "ERROR"); } default void logFatal(String message) { log(message, "FATAL"); } private static void getConnection() { System.out.println("Open Database connection"); } private static void closeConnection() { System.out.println("Close Database connection"); } }
Die Die laufenden Ergebnisse lauten wie folgt: $ javac InterfacePrivateMethodTester .java && java InterfacePrivateMethodTester
Datenbankverbindung öffnenProtokollmeldung: INFO FEHLER
Datenbankverbindung schließenDatenbankverbindung öffnen
Protokollmeldung: FATALDatenbankverbindung schließen
Datenbankverbindung öffnenProtokollmeldung: INFO
Datenbankverbindung schließenDatenbankverbindung öffnen
Protokollmeldung: WARNDatenbankverbindung schließen
Datenbankverbindung öffnenProtokoll Meldung: FEHLER
Datenbankverbindung schließenDatenbankverbindung öffnen Protokollmeldung: FATALDatenbankverbindung schließen
Das obige ist der detaillierte Inhalt vonSo verwenden Sie private Methoden von Schnittstellen in Java9. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Leitfaden zur perfekten Zahl in Java. Hier besprechen wir die Definition, Wie prüft man die perfekte Zahl in Java?, Beispiele mit Code-Implementierung.

Leitfaden für Weka in Java. Hier besprechen wir die Einführung, die Verwendung von Weka Java, die Art der Plattform und die Vorteile anhand von Beispielen.

Leitfaden zur Smith-Zahl in Java. Hier besprechen wir die Definition: Wie überprüft man die Smith-Nummer in Java? Beispiel mit Code-Implementierung.

In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Kapseln sind dreidimensionale geometrische Figuren, die aus einem Zylinder und einer Hemisphäre an beiden Enden bestehen. Das Volumen der Kapsel kann berechnet werden, indem das Volumen des Zylinders und das Volumen der Hemisphäre an beiden Enden hinzugefügt werden. In diesem Tutorial wird erörtert, wie das Volumen einer bestimmten Kapsel in Java mit verschiedenen Methoden berechnet wird. Kapselvolumenformel Die Formel für das Kapselvolumen lautet wie folgt: Kapselvolumen = zylindrisches Volumenvolumen Zwei Hemisphäre Volumen In, R: Der Radius der Hemisphäre. H: Die Höhe des Zylinders (ohne die Hemisphäre). Beispiel 1 eingeben Radius = 5 Einheiten Höhe = 10 Einheiten Ausgabe Volumen = 1570,8 Kubikeinheiten erklären Berechnen Sie das Volumen mithilfe der Formel: Volumen = π × R2 × H (4

Spring Boot vereinfacht die Schaffung robuster, skalierbarer und produktionsbereiteter Java-Anwendungen, wodurch die Java-Entwicklung revolutioniert wird. Der Ansatz "Übereinkommen über Konfiguration", der dem Feder -Ökosystem inhärent ist, minimiert das manuelle Setup, Allo
