普通类,抽象类和接口之间的区别

简介: 普通类,抽象类和接口之间的区别

一、普通类、抽象类和接口区别:


1. 普通类可以实例化,接口都不能被实例化(它没有构造方法),抽象类如果要实例化,抽象类必须指向实现所有抽象方法的子类对象(抽象类可以直接实例化,直接重写自己的抽象方法),接口必须指向实现所有所有接口方法的类对象。


2. 抽象类要被子类继承,接口要被子类实现。


3. 接口只能做方法的声明,抽象类可以做方法的声明,也可以做方法的实现。


4. 接口里定义的变量只能是公共的静态常量,抽象类中定义的变量是普通变量。


5. 抽象类里的抽象方法必须全部被子类所实现,如果子类不能全部实现父类的抽象方法,那么该子类只能是抽象类。同样,一个实现接口的时候,如果不能全部实现接口方法,那么该类只能是抽象类。


6. 抽象方法只能声明,不能实现。接口是设计的结果,抽象类是重构的结果。


7. 抽象类里可以没有抽象方法。


8. 如果一个类里有抽象方法,那么该类只能是抽象类。


9. 抽象方法要被实现,所以不能是静态的,也不能是私有的。


10. 接口可以继承接口,并可多继承接口,但类只能单继承。(重要啊)


11. 接口中的常量:有固定的修饰符-public static final(不能用private和protected修饰/本质上都是static的而且是final类型的,不管加不加static修饰)。


12. 接口中的抽象方法:有固定的修饰符-public abstract 。


13、接口细节:


若接口中方法或变量没有写public,static,final / public,abstract ,会自动补齐 。


接口中的成员都是共有的。


接口与接口之间是继承关系,而且可以多继承。


接口不能被实例化


一个类可以实现多个接口


在java开发中,我们经常把常用的变量,定义在接口中,作为全局变量使用,访问形式:接口名.变量名。


一个接口不能继承其它的类,但是可以继承别的接口


一个重要的原则:当一个类实现了一个接口,要求该类把这个接口的所有方法全部实现


注意:


① 抽象类和接口都是用来抽象具体的对象的,但是接口的抽象级别更高。


② 抽象类可以有具体的方法和属性,接口只能有抽象方法和静态常量。


③ 抽象类主要用来抽象级别,接口主要用来抽象功能。


④ 抽象类中,且不包含任何的实现,派生类必须覆盖它们。接口中所有方法都必须是未实现的。


⑤ 接口方法,访问权限必须是公共的 public。


⑥ 接口内只能有公共方法,不能存在成员变量。


⑦ 接口内只能包含未被实现的方法,也叫抽象方法,但是不能用 abstract 关键字。


⑧ 抽象类的访问速度比接口要快,接口是稍微有点慢,因为它需要时间去寻找在类中实现的方法。


⑨ 抽象类,除了不能被实例化外,与普通 java 类没有任何区别。


⑩ 抽象类可以有 main 方法,接口没有 main 方法。


⑪ 抽象类可以用构造器,接口没有。


⑫ 抽象方法可以有 public、protected 和 default 这些修饰符,接口只能使用默认 public。


⑬ 抽象类,添加新方法可以提供默认的实现,不需要改变原有代码。接口添加新方法,子类必须实现。


⑭ 抽象类的子类用 extends 关键字继承,接口用 implements 来实现。



二、什么时候用抽象类和接口


1. 若果你拥有一些方法并且想让他们中的一些有默认实现,那就用抽象类。


2. 如果你想实现多重继承,那么必须使用接口。由于 java 不支持多继承,子类不能继承多个父类,但是可以实现多个接口,因此你可以使用接口来实现它。


3. 如果基本基本功能在不断变化,那么就需要使用抽象类。如果不断改变基本功能并且使用接口,那么所有实现类都需要改变。


相关文章
|
分布式计算 Java 关系型数据库
Linux中jar包启动和jar包后台运行的实现方式
Linux中jar包启动和jar包后台运行的实现方式
2120 0
|
存储 关系型数据库 MySQL
【赵渝强老师】执行MySQL的冷备份与冷恢复
冷备份是在数据库关闭状态下进行的备份,速度快且恢复简单,但备份期间数据库不可用。本文通过一个MySQL数据库的示例,详细演示了冷备份和恢复的步骤,包括备份文件、模拟错误、恢复数据等过程。
286 0
|
机器学习/深度学习 人工智能 自然语言处理
大语言模型的Scaling Law:如何随着模型大小、训练数据和计算资源的增加而扩展
在这篇文章中,我们将介绍使这些模型运作的秘密武器——一个由三个关键部分组成的法则:模型大小、训练数据和计算能力。通过理解这些因素如何相互作用和规模化,我们将获得关于人工智能语言模型过去、现在和未来的宝贵见解。
1601 7
大语言模型的Scaling Law:如何随着模型大小、训练数据和计算资源的增加而扩展
|
12月前
|
传感器 数据采集 监控
物联网 GE-PREDIX
GE-Predix 是一个由通用电气公司开发的工业互联网平台,旨在为工业设备提供连接、分析和管理服务。它支持设备数据的收集与分析,帮助企业优化运营效率,实现智能化转型。
|
SQL 监控 关系型数据库
实际应用中监控和诊断SQL语句执行情况的具体案例
实际应用中监控和诊断SQL语句执行情况的具体案例
234 3
|
JSON Java 数据处理
Unity 数据读取|(二)多种方式读取文本文件
Unity 数据读取|(二)多种方式读取文本文件
|
弹性计算 运维 安全
安全组介绍
安全组介绍
206 3
|
缓存 分布式计算 算法
优化Hadoop MapReduce性能的最佳实践
【8月更文第28天】Hadoop MapReduce是一个用于处理大规模数据集的软件框架,适用于分布式计算环境。虽然MapReduce框架本身具有很好的可扩展性和容错性,但在某些情况下,任务执行可能会因为各种原因导致性能瓶颈。本文将探讨如何通过调整配置参数和优化算法逻辑来提高MapReduce任务的效率。
1312 0
|
数据采集 安全 Python
Python爬虫遇到重定向URL问题时如何解决?
Python爬虫遇到重定向URL问题时如何解决?
连续五年!中国唯一!入选Gartner ABI魔力象限!
连续五年!中国唯一!入选Gartner ABI魔力象限!
328 0