-
引入抽象类和接口的原因
即"针对接口编程",关键就在多态,即向上转型
当变量的的声明类型是超类型时,即抽象类或者接口,这样,只要是具体实现此超类型的类所产生的对象,都可以指定给这个变量,而不用分别为不同的对象声明不同的变量
-
抽象类和接口的不同
接口,只能明确方法名,但是没有实现
当已经明确了需要的超类型中的某个方法的实现时,就可以用抽象类,因为这样可以避免每个实现类的共同方法的冗余。(抽象类中可以有方法的实现)
当需要的超类型中的所有方法的实现都不相同但是方法名完全相同时,可以用接口(接口的所有方法都要被实现类实现)。
当需要多继承时,也要用到接口。
相关文章
- 【java】抽象类和接口(了解,进阶,到全部掌握)
- java 面向对象三大特性(封装,继承,多态)以及抽象、接口的介绍
- 家庭事务管理系统|基于java和vue的家庭事务管理系统设计与实现(源码+数据库+文档)
- 浅谈Python和Java的多进程与多线程的异同
- Java—继承性与多态性
- 头歌--Java面向对象 - 封装、继承和多态的综合练习
- 头歌--Java面向对象 - 封装、继承和多态
- RabbitMQ 优点和缺点- 消息可靠性:RabbitMQ 提供了持久化功能和消息确认机制,确保消息在各种情况下都能可靠地存储和处理。 灵活的路由:通过多种交换机类型和绑定规则,RabbitMQ 能够灵活地路由消息到指定的队列。 支持多种消息协议:实现了 AMQP 等(MQTT、STOMP)标准化、开放的消息队列协议,使其能够与多种语言编写的应用程序进行通信。 插件化扩展:RabbitMQ 提供了丰富的插件系统,可以通过插件扩展功能,如死信队列、压缩、追踪等。 高可用性:支持集群模式和镜像队列,确保服务的可用性 易用性和可管理性:提供了丰富的 API 和管理工具,以及多种客户端库和框架支持,易于集成和使用。 多语言支持:RabbitMQ 支持多种编程语言的客户端,包括 Java、Python、Ruby、C#、Node.js 等,方便开发人员集成到各种应用中。 高性能:在处理大量并发消息时表现出色。 广泛的社区支持:拥有庞大的开发者社区和丰富的文档资源。 劣势: 性能和吞吐量较低:相比于 Apache Kafka 等面向大数据流处理的消息队列系统,RabbitMQ 的吞吐量较低,不适合处理海量的实时数据流。RabbitMQ 的设计更注重消息的可靠性和灵活性,而非极高的吞吐性能。
- Java基础:多态(重载和重写)
- Go语言接口与多态