Jadual Kandungan
1. Pengenalan
2. Fahami
3 Gunakan antara muka
四、应用:代理模式(Proxy)
1. 应用场景
2. 分类
3. 代码演示
五、接口和抽象类之间的对比
六、经典题目(排错)
Rumah Java javaTutorial Apakah kaedah penggunaan tersuai antara muka Java?

Apakah kaedah penggunaan tersuai antara muka Java?

Apr 22, 2023 pm 11:34 PM
java

Apakah kaedah penggunaan tersuai antara muka Java?

1. Pengenalan

Di satu pihak, kadangkala perlu untuk mendapatkan subkelas daripada beberapa kelas dan mewarisi semua sifat dan kaedahnya. Walau bagaimanapun, Java tidak menyokong pelbagai warisan. Dengan antara muka, anda boleh mendapatkan kesan warisan berbilang.
Sebaliknya, kadangkala perlu mengekstrak beberapa ciri tingkah laku biasa daripada beberapa kelas, dan tidak ada hubungan antara mereka, mereka hanya mempunyai ciri tingkah laku yang sama. Contohnya: tetikus, papan kekunci, pencetak, pengimbas, kamera, pengecas, pemain MP3, telefon mudah alih, kamera digital, pemacu keras mudah alih, dsb. semuanya menyokong sambungan USB.

2. Fahami

Antaramuka ialah spesifikasi, yang mentakrifkan satu set peraturan yang merangkumi "jika anda/mahu..., anda mesti boleh. .." di alam nyata Fikiran. Warisan ialah hubungan "adakah", manakala pelaksanaan antara muka ialah hubungan "bolehkah".

Intipati antara muka ialah kontrak, piawaian dan spesifikasi, sama seperti undang-undang kita. Setelah dirumus, semua orang mesti mematuhinya.

3 Gunakan antara muka

untuk mentakrifkannya menggunakan kata kunci interface.

Di Java, antara muka dan kelas berada dalam hubungan selari, atau antara muka boleh difahami sebagai kelas khas. Pada dasarnya, antara muka ialah kelas abstrak khas yang hanya mengandungi takrifan pemalar dan kaedah (JDK7.0 dan sebelumnya), tanpa pelaksanaan pembolehubah dan kaedah.
Format sintaks untuk mentakrifkan kelas Java: tulis extends dahulu, kemudian implements

class SubClass extends SuperClass implements InterfaceA{ }
Salin selepas log masuk

Antaramuka (interface) ditakrifkan oleh kaedah abstrak dan nilai tetap berkumpul.

Cara mentakrifkan antara muka:

JDK7 dan sebelumnya: hanya pemalar global dan kaedah abstrak boleh ditakrifkan

  1. Semua pembolehubah ahli dalam antara muka diubah suai oleh public static final secara lalai dan boleh diabaikan.

  2. Semua kaedah abstrak dalam antara muka diubah suai oleh public abstract secara lalai.

Demonstrasi kod:

public interface Runner {
  int ID = 1;//<=>public static final int ID = 1;
  void start();//<=>public abstract void start();
  public void run();//<=>public abstract void run();
  void stop();//<=>public abstract void stop();}
Salin selepas log masuk

JDK8: Selain mentakrifkan pemalar global dan kaedah abstrak, anda juga boleh mentakrifkan kaedah statik dan lalai kaedah .

  1. Kaedah statik: Gunakan static pengubahsuaian kata kunci.
    Kaedah statik yang ditakrifkan dalam antara muka hanya boleh dipanggil melalui antara muka dan laksanakan badan kaedahnya. Kami sering menggunakan kaedah statik dalam kelas yang digunakan bersama antara satu sama lain. Anda boleh menemui pasangan antara muka dan kelas seperti Collection/Collections atau Path/Paths dalam pustaka standard.

  2. Kaedah lalai: Kaedah lalai diubah suai dengan kata kunci default. Boleh dipanggil dengan melaksanakan objek kelas. Kami menyediakan kaedah baharu dalam antara muka sedia ada sambil mengekalkan keserasian dengan versi kod yang lebih lama. Contohnya: Java 8 API menyediakan kaedah lalai yang kaya untuk antara muka seperti Collection, List dan Comparator.
    ● Jika antara muka mentakrifkan kaedah lalai, dan antara muka lain juga mentakrifkan kaedah dengan nama yang sama dan parameter yang sama (tidak kira sama ada kaedah ini ialah kaedah lalai), apabila kelas pelaksanaan melaksanakan kedua-dua antara muka, Konflik antara muka akan muncul.
    Penyelesaian: Kelas pelaksanaan mesti mengatasi kaedah dengan nama dan parameter yang sama dalam antara muka untuk menyelesaikan konflik.
    ● Jika antara muka mentakrifkan kaedah lalai, dan kelas induk juga mentakrifkan kaedah bukan abstrak dengan nama dan parameter yang sama, maka subkelas akan memanggil kaedah dalam kelas induk secara lalai jika ia tidak mengatasi kaedah ini . Kaedah dengan nama dan parameter yang sama tidak akan menyebabkan konflik. Kerana pada masa ini kami mematuhi: prinsip keutamaan kelas. Kaedah lalai dalam antara muka dengan nama dan parameter yang sama diabaikan.
    ● Bagaimana untuk memanggil kaedah yang diganti dalam kelas induk atau antara muka dalam kaedah subkelas (atau kelas pelaksanaan)?

Demonstrasi Kod 1:

public void myMethod(){
		method3();//调用自己定义的重写的方法
		super.method3();//调用的是父类中声明的
		//调用接口中的默认方法
		CompareA.super.method3();
		CompareB.super.method3();
	}
Salin selepas log masuk

Demonstrasi Kod 2:

interface Filial {// 孝顺的
	default void help() {
		System.out.println("老妈,我来救你了");
	}}interface Spoony {// 痴情的
	default void help() {
		System.out.println("媳妇,别怕,我来了");
	}}class Father{
	public void help(){
		System.out.println("儿子,就我媳妇!");
	}}class Man extends Father implements Filial, Spoony {
	@Override
	public void help() {
		System.out.println("我该就谁呢?");
		Filial.super.help();
		Spoony.super.help();
	}	}
Salin selepas log masuk

Pembina tidak boleh ditakrifkan dalam antara muka! Ini bermakna antara muka tidak boleh dibuat seketika.

Antara muka menggunakan mekanisme pewarisan berbilang. Pelbagai antara muka boleh dilaksanakan, menebus batasan warisan tunggal Java.
Format: class AA extends BB implements CC,DD,EE;

Dalam pembangunan Java, antara muka digunakan dengan membenarkan kelas melaksanakannya (implements).
Jika kelas pelaksanaan merangkumi semua kaedah abstrak dalam antara muka, kelas pelaksanaan ini boleh dijadikan instantiated.
Jika kelas pelaksanaan tidak meliputi semua kaedah abstrak dalam antara muka, kelas pelaksanaan masih merupakan kelas abstrak.

Demonstrasi kod:

/*
实现类SubAdapter必须给出接口SubInterface以及父接口MyInterface
中所有方法的实现。否则,SubAdapter仍需声明为abstract的。
*/interface MyInterface{
    String s=“MyInterface”;
    public void absM1();
    }interface SubInterface extends MyInterface{
    public void absM2();
    }public class SubAdapter implements SubInterface{
    public void absM1(){System.out.println(“absM1”);}
    public void absM2(){System.out.println(“absM2”);}}
Salin selepas log masuk

Antara muka boleh diwarisi antara satu sama lain dan berbilang warisan mungkin.

Sesuatu kelas boleh melaksanakan berbilang antara muka yang tidak berkaitan.

Demonstrasi Kod:

interface Runner { public void run();}interface Swimmer {public double swim();}class Creator{public int eat(){…}} class Man extends Creator implements Runner ,Swimmer{
    public void run() {……}
    public double swim() {……}
    public int eat() {……}}
Salin selepas log masuk

Sama seperti perhubungan warisan, terdapat polimorfisme antara antara muka dan kelas pelaksanaan

Demonstrasi Kod :

public class Test{
  public static void main(String args[]){
    Test t = new Test();
    Man m = new Man();
    t.m1(m);
    t.m2(m);
    t.m3(m);
  }
  public String m1(Runner f) { f.run(); }
  public void m2(Swimmer s) {s.swim();}
  public void m3(Creator a) {a.eat();}}
Salin selepas log masuk

Objek antara muka tanpa nama kelas pelaksanaan tanpa nama

Demonstrasi kod:

public class USBTest {
	public static void main(String[] args) {
		
		Computer com = new Computer();
		//1.创建了接口的非匿名实现类的非匿名对象
		Flash flash = new Flash();
		com.transferData(flash);
		
		//2. 创建了接口的非匿名实现类的匿名对象
		com.transferData(new Printer());
		
		//3. 创建了接口的匿名实现类的非匿名对象
		USB phone = new USB(){
			@Override
			public void start() {
				System.out.println("手机开始工作");
			}
			@Override
			public void stop() {
				System.out.println("手机结束工作");
			}			
		};
		com.transferData(phone);
		
		
		//4. 创建了接口的匿名实现类的匿名对象
		
		com.transferData(new USB(){
			@Override
			public void start() {
				System.out.println("mp3开始工作");
			}

			@Override
			public void stop() {
				System.out.println("mp3结束工作");
			}
		});
	}}class Computer{	
	public void transferData(USB usb){//USB usb = new Flash();
		usb.start();		
		System.out.println("具体传输数据的细节");		
		usb.stop();
	}		}interface USB{
	//常量:定义了长、宽、最大最小的传输速度等	
	void start();	
	void stop();	}class Flash implements USB{
	@Override
	public void start() {
		System.out.println("U盘开启工作");
	}
	@Override
	public void stop() {
		System.out.println("U盘结束工作");
	}	}class Printer implements USB{
	@Override
	public void start() {
		System.out.println("打印机开启工作");
	}
	@Override
	public void stop() {
		System.out.println("打印机结束工作");
	}	}
Salin selepas log masuk

四、应用:代理模式(Proxy)

1. 应用场景

安全代理:屏蔽对真实角色的直接访问。

远程代理:通过代理类处理远程方法调用(RMI)。

延迟加载:先加载轻量级的代理对象,真正需要再加载真实对象,比如你要开发一个大文档查看软件,大文档中有大的图片,有可能一个图片有100MB,在打开文件时,不可能将所有的图片都显示出来,这样就可以使用代理模式,当需要查看图片时,用proxy来进行大图片的打开。

2. 分类

静态代理(静态定义代理类)
动态代理(动态生成代理类)

3. 代码演示

//举例一:interface Network {
    public void browse();
    }// 被代理类class RealServer implements Network { @Override
    public void browse() {
    System.out.println("真实服务器上
    网浏览信息");
    } }// 代理类class ProxyServer implements Network {
    private Network network;
    public ProxyServer(Network network) {
    this.network = network; }
    public void check() {
    System.out.println("检查网络连接等操作");}
    public void browse() {
    check();
    network.browse();
    } }public class ProxyDemo {
    public static void main(String[] args) {
    Network net = new ProxyServer(new
    RealServer());
    net.browse();
    } }//举例二:public class StaticProxyTest {
	public static void main(String[] args) {
		Proxy s = new Proxy(new RealStar());
		s.confer();
		s.signContract();
		s.bookTicket();
		s.sing();
		s.collectMoney();
	}}interface Star {
	void confer();// 面谈
	void signContract();// 签合同
	void bookTicket();// 订票
	void sing();// 唱歌
	void collectMoney();// 收钱}//被代理类class RealStar implements Star {
	public void confer() {
	}
	public void signContract() {
	}
	public void bookTicket() {
	}
	public void sing() {
		System.out.println("明星:歌唱~~~");
	}
	public void collectMoney() {
	}}//代理类class Proxy implements Star {
	private Star real;
	public Proxy(Star real) {
		this.real = real;
	}
	public void confer() {
		System.out.println("经纪人面谈");
	}
	public void signContract() {
		System.out.println("经纪人签合同");
	}
	public void bookTicket() {
		System.out.println("经纪人订票");
	}
	public void sing() {
		real.sing();
	}
	public void collectMoney() {
		System.out.println("经纪人收钱");
	}}
Salin selepas log masuk

五、接口和抽象类之间的对比

No.区别点抽象类接口
1定义包含抽象方法的类主要是抽象方法和全局常量的集合
2组成构造方法、抽象方法、普通方法、常量、变量常量、抽象方法、(jdk8.0:默认方法、静态方法)
3使用子类继承抽象类(extends)子类实现接口(implements)
4关系抽象类可以实现多个接口接口不能继承抽象类,但允许继承多个接口
5常见设计模式模板方法简单工厂、工厂方法、代理模式
6对象都通过对象的多态性产生实例化对象都通过对象的多态性产生实例化对象
7局限抽象类有单继承的局限接口没有此局限
8实际作为一个模板是作为一个标准或是表示一种能力
9选择如果抽象类和接口都可以使用的话,优先使用接口,因为避免单继承的局限如果抽象类和接口都可以使用的话,优先使用接口,因为避免单继承的局限

六、经典题目(排错)

//题目一:interface A {
    int x = 0;
    }class B {
    int x = 1;
    }class C extends B implements A {
    public void pX() {
    System.out.println(x);
    }public static void main(String[] args) {
    new C().pX();
    } }//题目二:interface Playable {
    void play();
    }interface Bounceable {
    void play();}interface Rollable extends Playable, Bounceable {
    Ball ball = new Ball("PingPang");}class Ball implements Rollable {
    private String name;
    public String getName() {
    return name; 
    }
    public Ball(String name) {
    this.name = name; 
    }
    public void play() {
    ball = new Ball("Football");
    System.out.println(ball.getName());
    } }
Salin selepas log masuk

Atas ialah kandungan terperinci Apakah kaedah penggunaan tersuai antara muka Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Nombor Sempurna di Jawa Nombor Sempurna di Jawa Aug 30, 2024 pm 04:28 PM

Panduan Nombor Sempurna di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor Perfect dalam Java?, contoh dengan pelaksanaan kod.

Weka di Jawa Weka di Jawa Aug 30, 2024 pm 04:28 PM

Panduan untuk Weka di Jawa. Di sini kita membincangkan Pengenalan, cara menggunakan weka java, jenis platform, dan kelebihan dengan contoh.

Nombor Smith di Jawa Nombor Smith di Jawa Aug 30, 2024 pm 04:28 PM

Panduan untuk Nombor Smith di Jawa. Di sini kita membincangkan Definisi, Bagaimana untuk menyemak nombor smith di Jawa? contoh dengan pelaksanaan kod.

Soalan Temuduga Java Spring Soalan Temuduga Java Spring Aug 30, 2024 pm 04:29 PM

Dalam artikel ini, kami telah menyimpan Soalan Temuduga Spring Java yang paling banyak ditanya dengan jawapan terperinci mereka. Supaya anda boleh memecahkan temuduga.

Cuti atau kembali dari Java 8 Stream Foreach? Cuti atau kembali dari Java 8 Stream Foreach? Feb 07, 2025 pm 12:09 PM

Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah

TimeStamp to Date in Java TimeStamp to Date in Java Aug 30, 2024 pm 04:28 PM

Panduan untuk TimeStamp to Date di Java. Di sini kita juga membincangkan pengenalan dan cara menukar cap waktu kepada tarikh dalam java bersama-sama dengan contoh.

Program Java untuk mencari kelantangan kapsul Program Java untuk mencari kelantangan kapsul Feb 07, 2025 am 11:37 AM

Kapsul adalah angka geometri tiga dimensi, terdiri daripada silinder dan hemisfera di kedua-dua hujungnya. Jumlah kapsul boleh dikira dengan menambahkan isipadu silinder dan jumlah hemisfera di kedua -dua hujungnya. Tutorial ini akan membincangkan cara mengira jumlah kapsul yang diberikan dalam Java menggunakan kaedah yang berbeza. Formula volum kapsul Formula untuk jumlah kapsul adalah seperti berikut: Kelantangan kapsul = isipadu isipadu silinder Dua jumlah hemisfera dalam, R: Radius hemisfera. H: Ketinggian silinder (tidak termasuk hemisfera). Contoh 1 masukkan Jejari = 5 unit Ketinggian = 10 unit Output Jilid = 1570.8 Unit padu menjelaskan Kirakan kelantangan menggunakan formula: Kelantangan = π × r2 × h (4

Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Cipta Masa Depan: Pengaturcaraan Java untuk Pemula Mutlak Oct 13, 2024 pm 01:32 PM

Java ialah bahasa pengaturcaraan popular yang boleh dipelajari oleh pembangun pemula dan berpengalaman. Tutorial ini bermula dengan konsep asas dan diteruskan melalui topik lanjutan. Selepas memasang Kit Pembangunan Java, anda boleh berlatih pengaturcaraan dengan mencipta program "Hello, World!" Selepas anda memahami kod, gunakan gesaan arahan untuk menyusun dan menjalankan program, dan "Hello, World!" Pembelajaran Java memulakan perjalanan pengaturcaraan anda, dan apabila penguasaan anda semakin mendalam, anda boleh mencipta aplikasi yang lebih kompleks.

See all articles