zoukankan      html  css  js  c++  java
  • 抽象类和接口的区别

    1.抽象类:抽象类不能创建实例对象。含有抽象方法的类必须为抽象类。抽象类中的抽象方法必须在子类中实现,所以不能有抽象构造方法或抽象静态方法。如果子类没有实现抽象类中的抽象方法,那么子类也必须定义为抽象类。但是抽象类中可以有普通的方法。
    2.接口(interface)可以说成是抽象类的一种特例,接口中的所有方法都必须是抽象的。接口中的方法定义默认为public abstract类型,接口中的成员变量类型默认为public static final。
    下面比较一下两者的语法区别:

    a.抽象类可以有构造方法,普通成员变量,非抽象的普通方法,抽象类中的方法访问类型可以为public,protected。可以包含静态方法。可以包含任意访问类型的静态成员变量。

    b.接口中不能有构造方法,不能有普通成员变量,所有的方法必须都是抽象的,抽象方法只能是public类型,不可以包含静态方法。只能包含public static final类型的变量。
    下面接着再说说两者在应用上的区别:

    a.接口更多的是在系统架构设计方法发挥作用,主要用于定义模块之间的通信契约。

    b.抽象类在代码的实现方面发挥作用,可以实现代码的重用。模板方法设计模式是抽象类的一个典型应用。例如:Servlet类都要用相同的方式进行权限判断、记录访问日志和处理异常,那么可以定义一个抽象的基类,让所有的Servlet都继承这个抽象类。
    在抽象基类的service方法中完成权限判断、记录访问日志和处理异常的代码,在各个子类中只是完成各自的业务逻辑代码,伪代码如下:
    public abstract class BaseServlet extends HttpServlet
    {
    public final void service(HttpServletRequest request, HttpServletResponse response) throws IOExcetion,ServletException
    {
    记录访问日志
    进行权限判断
    if(具有权限)
    {
    try
    {
    doService(request,response);
    }
    catch(Excetpion e)
    {
    记录异常信息
    }
    }
    } 
    protected abstract void doService(HttpServletRequest request, HttpServletResponse response) throws IOExcetion,ServletException; 
    //注意访问权限定义成protected,显得既专业,又严谨,因为它是专门给子类用的
    }

    public class MyServlet1 extends BaseServlet
    {
    protected void doService(HttpServletRequest request, HttpServletResponse response) throws IOExcetion,ServletException
    {
    本Servlet只处理的具体业务逻辑代码
    } 

    }
    父类方法中间的某段代码不确定,留给子类干,就用模板方法设计模式。
    备注:这道题的思路是先从总体解释抽象类和接口的基本概念,然后再比较两者的语法细节,最后再说两者的应用区别。比较两者语法细节区别的条理是:先从一个类中的构造方法、普通成员变量和方法(包括抽象方法),静态变量和方法,继承性等6个方面逐一去比较回答,接着从第三者继承的角度的回答,特别是最后用了一个典型的例子来展现自己深厚的技术功底。

  • 相关阅读:
    vue typescript: Parameter ‘XXX’ implicitly has an ‘any’ type.解决方法
    ESLint学习(一)简介、安装、配置、命令行、规则
    使用vite搭建vue3项目(三) 配置国际化
    VUE3+Typescript 引用process提示错误
    centos7安装vsftpd,配置
    使用vite搭建vue3项目(一) 创建一个工程
    Symbols 是 JavaScript 最新推出的一种基本类型
    使用vite搭建vue3项目(二) 引入vuerouter
    在使用vite时使用import.meta.globEager 代替 require.context 自动导入文件
    VUE3.X版本error: Parsing error: Parsing error: Unexpected token 的解决办法
  • 原文地址:https://www.cnblogs.com/hupp/p/4852688.html
Copyright © 2011-2022 走看看