博客
关于我
抽象类和接口详解
阅读量:477 次
发布时间:2019-03-06

本文共 1603 字,大约阅读时间需要 5 分钟。

如何区分抽抽象类和接口?

在讲解Java编程时,抽象类和接口的区别总是让人感到混淆。大家可能会问:什么时候该用抽象类,什么时候该用接口?其实这个问题有一个非常直观的答案:抽象类描述的是事物的本质,而接口描述的是事物的功能。

举个简单的例子:保温杯和水杯。水杯是所有保温杯的基础,它应该设计成一个抽象类。而保温这个功能则应该设计成一个接口。这样,无论是普通水杯还是保温杯,都可以继承水杯这个抽象类,同时实现保温接口。

让我们通过代码来理解这个概念:

package zmldemo;public abstract class Cup {    String name; // 水杯名称    String color; // 水杯颜色    public Cup() {}    public Cup(String name, String color) {        this.name = name;        this.color = color;    }    // 水杯使用说明方法    public abstract void useCup();}
package zmldemo;public interface BaoWen {    // 保温方法    void baoWen();}
package zmldemo;public class ShuaYaBei extends Cup {    public ShuaYaBei() {}    public ShuaYaBei(String name, String color) {        super(name, color);    }    @Override    public void useCup() {        System.out.println("我是" + this.color + "的" + this.name + ",我是用来刷牙的");    }}
package zmldemo;public class BaoWenBei extends Cup implements BaoWen {    public BaoWenBei() {}    public BaoWenBei(String name, String color) {        super(name, color);    }    @Override    public void useCup() {        System.out.println("我是" + this.color + "的" + this.name + ",我是用来喝水的");    }    @Override    public void baoWen() {        System.out.println("我能对水杯里的水进行保温");    }}
package zmldemo;public class CupTest {    public static void main(String[] args) {        ShuaYaBei shuaYaBei = new ShuaYaBei("刷牙杯", "红色");        shuaYaBei.useCup();        BaoWenBei baoWenBei = new BaoWenBei("保温杯", "金黄色");        baoWenBei.useCup();        baoWenBei.baoWen();    }}

通过上述代码可以看出,抽象类和接口的主要区别在于它们的设计目的。抽象类描述的是一个事物的本质特性,而接口描述的是一个事物的功能特性。抽象类强调的是“是什么”,而接口强调的是“能做什么”。

转载地址:http://skzdz.baihongyu.com/

你可能感兴趣的文章
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>