千字打通接口的任督二脉 | 带你学《Java面向对象编程》之五十八

简介: 本节为读者讲述了接口使用过程中遇到的转型问题以及接口与抽象类之间对于子类的继承、实现的要求。

上一篇:初识“多继承小帮手”-接口 | 带你学《Java面向对象编程》之五十七
【本节目标】
通过阅读本节内容,你将了解到使用接口时的几种转型情况与接口内访问权限的相关情况,学会正确的继承抽象类、实现接口,并能熟练处理接口对象的转型操作。

对象转型

但是这个时候我们就需要考虑一个实际的情况了,关于对象的转型问题了。

image.png
图一 对象转型

此时MessageImpl子类的对象可以任意的实现父接口的转换
范例:观察转换

interface IMessage {    //定义了一个接口
    public static final String INFO = “www.mldn.cn” ;  //全局常量
    public abstract String getInfo() ;    //抽象方法
}
interface IChannel {
    public abstract boolean connect() ;   //定义抽象方法
}
class MessageImpl implements IMessage, IChannel{    //实现了接口
    public String getInfo() {
        if(this.connect()) {
           return “得到一个消息,秘密的消息,有人胖了。”
        }
        return “通道创建失败,无法获取消息。”
    }
    public boolean connect() {
        System.out.println(“消息发送通道已经成功建立。”) ;
        return true ;
    }
}
public class JavaDemo {
    public static void main(String args[]) {
        IMessage msg = new MessageImpl() ;
        IChannel chl = (IChannel) msg ;
        System.out.println(chl.connect()) ;
    }
}

执行结果:
消息发送通道已经成功建立。
true

由于MessageImpl子类实现了IMessage与IChannel两个接口,所以这个子类可以是这两个接口任意一个接口的实例,那么就表示此时这两个接口实例之间是可以转换的。
在Java程序里面接口是不允许去继承父类的,所以说接口绝对不会是Object的子类,但是根据之前的分析可以发现,MessageImpl是Object子类,所以接口一定可以通过Object接收。
范例:观察Object与接口转换

interface IMessage {    //定义了一个接口
    public static final String INFO = “www.mldn.cn” ;  //全局常量
    public abstract String getInfo() ;    //抽象方法
}
interface IChannel {
    public abstract boolean connect() ;   //定义抽象方法
}
class MessageImpl implements IMessage, IChannel{    //实现了接口
    public String getInfo() {
        if(this.connect()) {
           return “得到一个消息,秘密的消息,有人胖了。”
        }
        return “通道创建失败,无法获取消息。”
    }
    public boolean connect() {
        System.out.println(“消息发送通道已经成功建立。”) ;
        return true ;
    }
}
public class JavaDemo {
    public static void main(String args[]) {
        IMessage msg = new MessageImpl() ;
        Object obj = msg ;     //向上转型
        IChannel chan = (IChannel) obj ;
        System.out.println(chan.connect()) ;
    }
}

执行结果:
消息发送通道已经成功建立。
true

Object类对象可以接收所有的数据类型,包括基本数据类型、类对象、接口对象、数组。
由于接口描述的是公共的定义标准,所以在接口之中所有的抽象方法的访问权限都为public,也就是说写与不写都是一样的,例如:下面的两个接口本质是完全相同的:
完整定义:

interface IMessage {    //定义了一个接口
    public static final String INFO = “www.mldn.cn” ;  
    public abstract String getInfo() ;    
}

简化定义:

interface IMessage {    //定义了一个接口
    String INFO = “www.mldn.cn” ;  
    String getInfo() ;    
}

方法不写访问权限也是public,不是default,所以覆写的时候只能够使用public。
接口虽然已经可以成功的进行定义,但是千万不要忽略,在实际的开发过程之中,实现接口的有可能是抽象类,也就是说一个抽象类可以实现多个接口,而一个普通类只能够继承一个抽象类并且可以实现多个父接口,但是要求先继承后实现。
范例:子类继承抽象类并且实现接口

interface IMessage {    //定义了一个接口
    public static final String INFO = “www.mldn.cn” ;  //全局常量
    public abstract String getInfo() ;    //抽象方法
}
interface IChannel {
    public abstract boolean connect() ;   //定义抽象方法
}
abstract class DatabaseAbstract {    //定义一个抽象类
     //接口中的abstract可以省略,抽象类中不允许省略
    public abstract boolean getDatabaseConnection() ;
}
class MessageImpl extends DatabaseAbstract implements IMessage, IChannel{    //实现了接口
    public String getInfo() {
        if(this.connect()) {
          if (this. getDatabaseConnection()) {
             return “得到一个消息,秘密的消息,有人胖了。”
          }elae {
             return “数据库消息无法访问。”
          }
        }
        return “通道创建失败,无法获取消息。”
    }
    public boolean connect() {
        System.out.println(“消息发送通道已经成功建立。”) ;
        return true ;
    }
    public boolean getDatabaseConnection() {
        return true ;
    }
}
public class JavaDemo {
    public static void main(String args[]) {
        IMessage msg = new MessageImpl() ;
        System.out.println(msg.getInfo()) ;
    }
}

执行结果:
消息发送通道已经成功建立。
得到一个消息,秘密的消息,有人胖了。

虽然接口无法去继承一个父类,但是一个接口却可以通过extends继承若干个父接口,此时称为接口的多继承。
范例:实现接口的多继承

interface IMessage {    
    public abstract String getInfo() ;    //抽象方法
}
interface IChannel {
    public boolean connect() ;
}
//extends在类继承上只能够继承一个父类,但是接口上可以继承多个
interface IService extends IMessage ,IChannel {    //接口多继承
    public String service() ;
}
class MessageService implements IService {
    public String getInfo() {
        return null ;
    }
    public boolean connect() {
        return true ;
    }
    public String service() {
        return “获取消息服务。”
    }
}

在实际的开发之中,接口的使用往往有三种形式:
进行标准设置;
表示一种操作的能力;
暴露远程方法视图,这个一般都在RPC分布式开发中使用。

想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学

下一篇:接口的魅力:全能的世界蓝图 | 带你学《Java面向对象编程》之五十九
更多Java面向对象编程文章查看此处

相关文章
|
2月前
|
存储 缓存 安全
Java集合框架(二):Set接口与哈希表原理
本文深入解析Java中Set集合的工作原理及其实现机制,涵盖HashSet、LinkedHashSet和TreeSet三大实现类。从Set接口的特性出发,对比List理解去重机制,并详解哈希表原理、hashCode与equals方法的作用。进一步剖析HashSet的底层HashMap实现、LinkedHashSet的双向链表维护顺序特性,以及TreeSet基于红黑树的排序功能。文章还包含性能对比、自定义对象去重、集合运算实战和线程安全方案,帮助读者全面掌握Set的应用与选择策略。
164 23
|
2月前
|
存储 安全 Java
Java集合框架(一):List接口及其实现类剖析
本文深入解析Java中List集合的实现原理,涵盖ArrayList的动态数组机制、LinkedList的链表结构、Vector与Stack的线程安全性及其不推荐使用的原因,对比了不同实现的性能与适用场景,帮助开发者根据实际需求选择合适的List实现。
|
2月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
2月前
|
安全 Java 开发者
Java集合框架:详解Deque接口的栈操作方法全集
理解和掌握这些方法对于实现像浏览器后退功能这样的栈操作来说至关重要,它们能够帮助开发者编写既高效又稳定的应用程序。此外,在多线程环境中想保证线程安全,可以考虑使用ConcurrentLinkedDeque,它是Deque的线程安全版本,尽管它并未直接实现栈操作的方法,但是Deque的接口方法可以相对应地使用。
129 12
|
2月前
|
Java API 网络架构
java调用api接口自动判断节假日信息
java调用api接口自动判断节假日信息
705 0
|
2月前
|
消息中间件 缓存 前端开发
从资损百万到零事故:Java 接口幂等设计的艺术与实践
在分布式系统中,重复请求常引发严重资损,如支付双扣、库存超卖等问题,其根源在于接口缺乏幂等性设计。本文通过真实案例揭示幂等性的重要性,并详解8种主流解决方案,涵盖唯一请求ID、乐观锁、悲观锁、状态机等,帮助开发者构建稳定系统,保障业务一致性。无论你是架构师还是开发工程师,都能从中获得实战指导,有效规避重复调用带来的风险。
152 0
|
3月前
|
存储 安全 Java
深入理解Java序列化接口及其实现机制
记住,序列化不仅仅是把对象状态保存下来那么简单,它涉及到类的版本控制、安全性和性能等多个重要方面。正确理解和实现Java序列化机制对于构建高效、安全和可维护的Java应用至关重要。
120 0
|
20天前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
59 0
|
1月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
88 16