博客
关于我
抽象类和接口详解
阅读量: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/

你可能感兴趣的文章
Oracle——distinct的用法
查看>>
Oracle、MySQL、SQL Server架构大对比
查看>>
oracle下的OVER(PARTITION BY)函数介绍
查看>>
Oracle中DATE数据相减问题
查看>>
Oracle中merge into的使用
查看>>
oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
查看>>
oracle中sql的case语句运用--根据不同条件去排序!
查看>>
Oracle中Transate函数的使用
查看>>
oracle中关于日期问题的汇总!
查看>>
Oracle中常用的语句
查看>>
Oracle中序列的操作以及使用前对序列的初始化
查看>>
oracle中新建用户和赋予权限
查看>>
Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
查看>>
Oracle中的rownum 和rowid的用法和区别
查看>>
oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
查看>>
oracle中表和视图的区别,oracle中常用表和视图
查看>>
oracle从备份归档日志的方法集中回收
查看>>
oracle优化器analyzed,Oracle 学习之 性能优化(十三) 索引
查看>>
Oracle修改字段类型
查看>>
Oracle修改表或者字段的注释
查看>>