java--接口

举报
brucexiaogui 发表于 2021/12/29 23:36:32 2021/12/29
【摘要】 java--接口 转载自:https://blog.csdn.net/wei_zhi/article/details/52738471 一、接口特性   接口只定义了类应当遵循的规范,却不关心这些类的内部数据和其方法内的实现细节接口只规定了这些类必须提供的方法,从而分离了规范和实现,增强了系统的可扩展性和维护性。 二、...

java--接口

转载自:https://blog.csdn.net/wei_zhi/article/details/52738471

一、接口特性

 

  • 接口只定义了类应当遵循的规范,却不关心这些类的内部数据和其方法内的实现细节
  • 接口只规定了这些类必须提供的方法,从而分离了规范和实现,增强了系统的可扩展性和维护性。

二、接口定义

 

  • 接口定义一种规范,规定一个类必须做什么,但他不管如何具体去做。
  • 【修饰符】interface 接口名称 extends 父接口1,父接口2.........
  • 没有构造方法,不能实例化;
  • 接口只能继承接口,不能继承类;
  • 接口里没有普通方法,方法全是抽象方法;
  • 接口里的方法默认修饰符是 public abstract;
  • 接口里的字段全是全局常量,默认修饰符是 public static final;
  • 接口里的成员包括:全局常量,公共的抽象方法,内部类(内部类,内部接口,内部枚举类);

三、接口的实现

 

1、由于接口里面存在抽象方法,所以接口对象不能直接使用关键字new进行实例化。接口的使用原则如下: 
(1)接口必须要有子类,但此时一个子类可以使用implements关键字实现多个接口; 
(2)接口的子类(如果不是抽象类),那么必须要覆写接口中的全部抽象方法; 
(3)接口的对象可以利用子类对象的向上转型进行实例化。

范例:

 


  
  1. package com.wz.interfacedemo;
  2. interface A{//定义一个接口A
  3. public static final String MSG = "hello";//全局常量
  4. public abstract void print();//抽象方法
  5. }
  6. interface B{//定义一个接口B
  7. public abstract void get();
  8. }
  9. class X implements A,B{//X类实现了A和B两个接口
  10. @Override
  11. public void print() {
  12. System.out.println("接口A的抽象方法print()");
  13. }
  14. @Override
  15. public void get() {
  16. System.out.println("接口B的抽象方法get()");
  17. }
  18. }
  19. public class TestDemo {
  20. public static void main(String[] args){
  21. X x = new X();//实例化子类对象
  22. A a = x;//向上转型
  23. B b = x;//向上转型
  24. a.print();
  25. b.get();
  26. }
  27. }

 

运行结果:

 


  
  1. 接口A的抽象方法print()
  2. 接口B的抽象方法get()

 

2、对于子类而言,除了实现接口外,还可以继承抽象类。若既要继承抽象类,同时还要实现接口的话,使用一下语法格式:

 

class 子类 [extends 父类] [implemetns 接口1,接口2,...] {}
 

 


  
  1. interface A{//定义一个接口A
  2. public static final String MSG = "hello";//全局常量
  3. public abstract void print();//抽象方法
  4. }
  5. interface B{//定义一个接口B
  6. public abstract void get();
  7. }
  8. abstract class C{//定义一个抽象类C
  9. public abstract void change();
  10. }
  11. class X extends C implements A,B{//X类继承C类,并实现了A和B两个接口
  12. @Override
  13. public void print() {
  14. System.out.println("接口A的抽象方法print()");
  15. }
  16. @Override
  17. public void get() {
  18. System.out.println("接口B的抽象方法get()");
  19. }
  20. @Override
  21. public void change() {
  22. System.out.println("抽象类C的抽象方法change()");
  23. }
  24. }

对于接口,里面的组成只有抽象方法和全局常量,所以很多时候为了书写简单,可以不用写public abstract 或者public static final。并且,接口中的访问权限只有一种:public,即:定义接口方法和全局常量的时候就算没有写上public,那么最终的访问权限也是public,注意不是default。以下两种写法是完全等价的:


  
  1. interface A{
  2. public static final String MSG = "hello";
  3. public abstract void print();
  4. }

等价于


  
  1. interface A{
  2. String MSG = "hello";
  3. void print();
  4. }

但是,这样会不会带来什么问题呢?如果子类子类中的覆写方法也不是public,我们来看:


  
  1. package com.wz.interfacedemo;
  2. interface A{
  3. String MSG = "hello";
  4. void print();
  5. }
  6. class X implements A{
  7. void print() {
  8. System.out.println("接口A的抽象方法print()");
  9. }
  10. }
  11. public class TestDemo {
  12. public static void main(String[] args){
  13. A a = new X();
  14. a.print();
  15. }
  16. }

运行结果:


  
  1. Exception in thread "main" java.lang.IllegalAccessError: com.wz.interfacedemo.X.print()V
  2. at com.wz.interfacedemo.TestDemo.main(TestDemo.java:22)

这是因为接口中默认是public修饰,若子类中没用public修饰,则访问权限变严格了,给子类分配的是更低的访问权限。所以,在定义接口的时候强烈建议在抽象方法前加上public ,子类也加上:


  
  1. interface A{
  2. String MSG = "hello";
  3. public void print();
  4. }
  5. class X implements A{
  6. public void print() {
  7. System.out.println("接口A的抽象方法print()");
  8. }
  9. }

3、在Java中,一个抽象类只能继承一个抽象类,但一个接口却可以使用extends关键字同时继承多个接口(但接口不能继承抽象类)。


  
  1. interface A{
  2. public void funA();
  3. }
  4. interface B{
  5. public void funB();
  6. }
  7. //C接口同时继承了A和B两个接口
  8. interface C extends A,B{//使用的是extends
  9. public void funC();
  10. }
  11. class X implements C{
  12. @Override
  13. public void funA() {
  14. }
  15. @Override
  16. public void funB() {
  17. }
  18. @Override
  19. public void funC() {
  20. }
  21. }

由此可见,从继承关系来说接口的限制比抽象类少: 
(1)一个抽象类只能继承一个抽象父类,而接口可以继承多个接口; 
(2)一个子类只能继承一个抽象类,却可以实现多个接口(在Java中,接口的主要功能是解决单继承局限问题)

4、从接口的概念上来讲,接口只能由抽象方法和全局常量组成,但是内部结构是不受概念限制的,正如抽象类中可以定义抽象内部类一样,在接口中也可以定义普通内部类、抽象内部类和内部接口(但从实际的开发来讲,用户自己去定义内部抽象类或内部接口的时候是比较少见的),范例如下,在接口中定义一个抽象内部类:

 


  
  1. interface A{
  2. public void funA();
  3. abstract class B{//定义一个抽象内部类
  4. public abstract void funB();
  5. }
  6. }

在接口中如果使用了static去定义一个内接口,它表示一个外部接口:


  
  1. interface A{
  2. public void funA();
  3. static interface B{//使用了static,是一个外部接口
  4. public void funB();
  5. }
  6. }
  7. class X implements A.B{
  8. @Override
  9. public void funB() {
  10. }
  11. }

三、接口的实际应用(标准定义)

在日常的生活之中,接口这一名词经常听到的,例如:USB接口、打印接口、充电接口等等。

 

 

如果要进行开发,要先开发出USB接口标准,然后设备厂商才可以设计出USB设备。

现在假设每一个USB设备只有两个功能:安装驱动程序、工作。 
定义一个USB的标准:

 


  
  1. interface USB { // 操作标准
  2. public void install() ;
  3. public void work() ;
  4. }

 

在电脑上应用此接口:

 


  
  1. class Computer {
  2. public void plugin(USB usb) {
  3. usb.install() ;
  4. usb.work() ;
  5. }
  6. }

定义USB设备—手机:


  
  1. class Phone implements USB {
  2. public void install() {
  3. System.out.println("安装手机驱动程序。") ;
  4. }
  5. public void work() {
  6. System.out.println("手机与电脑进行工作。") ;
  7. }
  8. }

定义USB设备—打印机:


  
  1. class Print implements USB {
  2. public void install() {
  3. System.out.println("安装打印机驱动程序。") ;
  4. }
  5. public void work() {
  6. System.out.println("进行文件打印。") ;
  7. }
  8. }

定义USB设备—MP3:


  
  1. class MP3 implements USB {
  2. public void install() {
  3. System.out.println("安装MP3驱动程序。") ;
  4. }
  5. public void work() {
  6. System.out.println("进行MP3拷贝。") ;
  7. }
  8. }

测试主类:


  
  1. public class TestDemo {
  2. public static void main(String args[]) {
  3. Computer c = new Computer() ;
  4. c.plugin(new Phone()) ;
  5. c.plugin(new Print()) ;
  6. c.plugin(new MP3());
  7. }
  8. }

运行结果:


  
  1. 安装手机驱动程序。
  2. 手机与电脑进行工作。
  3. 安装打印机驱动程序。
  4. 进行文件打印。
  5. 安装MP3驱动程序。
  6. 进行MP3拷贝。

可以看出,不管有多少个USB接口的子类,都可以在电脑上使用。 
在现实生活中,标准的概念随处可见,而在程序里标准使用接口定义的。

文章来源: brucelong.blog.csdn.net,作者:Bruce小鬼,版权归原作者所有,如需转载,请联系作者。

原文链接:brucelong.blog.csdn.net/article/details/79722008

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。