博客
关于我
抽象类和接口详解
阅读量: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数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>