Sebelum Java 8, antara muka nampaknya hanya membenarkan dua jenis data, satu adalah pemalar, satu lagi adalah kaedah maya awam (awam) (abstrak), dan ia ialah kaedah maya Oh, tiada kaedah pelaksanaan, kerana kaedah ini mesti dilaksanakan oleh kelas. Dalam erti kata lain, tiada kaedah dengan pelaksanaan lalai dalam versi sebelum Java 8.
Mari kita lihat contoh,
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(); }
Hasil larian adalah seperti berikut
$ javac InterfacePrivateMethodTester.java && java InterfacePrivateMethodTester
Open Sambungan pangkalan data
Mesej Log : INFO
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log : AMARAN
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log : RALAT
Tutup sambungan pangkalan data
Buka sambungan Pangkalan Data
Mesej Log : FATAL
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : INFO
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log : AMARAN
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : RALAT
Tutup Sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : FATAL
Tutup sambungan Pangkalan Data
Dalam contoh ini, setiap jenis log mempunyai pelaksanaannya sendiri
Apakah perangkap terbesar Setiap kaedah mesti dilaksanakan sekali? Ya, setiap kaedah mesti melaksanakan
dan Java 8 akhirnya telah membuat beberapa perubahan Antara Muka dalam Java 8 boleh mempunyai jenis pembolehubah dan kaedah berikut
1. .Malar
2. Kaedah maya
3. Kaedah lalai
4.
Keputusan yang dijalankan adalah seperti berikutpublic 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"); } }$ javac InterfacePrivateMethodTester.java && java InterfacePrivateMethodTester
Sambungan Pangkalan Data TerbukaMesej Log: >INFO
Buka sambungan Pangkalan Data
Mesej Log : AMARAN
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : RALAT
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log : FATAL
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : INFO
Tutup Sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : AMARAN
Tutup sambungan Pangkalan Data
Buka Sambungan pangkalan data
Mesej Log: RALAT
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log: FATAL
Tutup sambungan Pangkalan Data
Kerana Kaedah Java 8 dalam antara muka boleh mempunyai pelaksanaan lalai, iaitu kaedah yang diubah suai dengan kata kunci
Oleh itu, agak mudah untuk kelas melaksanakan antara muka tertentu dan beberapa kaedah boleh dilaksanakan secara terpilih. default
InterfacePrivateMethodTester.java
Jalankan Hasilnya adalah seperti berikut: AMARANTutup sambungan Pangkalan DataBuka Sambungan Pangkalan Data
Mesej Log : RALATpublic 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"); } }Tutup Sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log : FATALTutup sambungan Pangkalan DataBuka sambungan Pangkalan Data
Mesej Log: INFO
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log: AMARAN
Tutup sambungan Pangkalan Data
Buka sambungan Pangkalan Data
Mesej Log: RALAT
Tutup sambungan Pangkalan Data
Buka Sambungan Pangkalan Data
Mesej Log: FATAL
Tutup sambungan Pangkalan Data
Atas ialah kandungan terperinci Cara menggunakan kaedah peribadi antara muka dalam Java9. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!