[Thinking in java] _为什么要使用抽象类

感觉工作了之后没怎么用到抽象类 最近在看组内大佬的code的时候 发现很多抽象类的使用,所以去百度了一把:使用抽象类到底有哪些好处

=>  code by  信哥   转载注明出处 

/**
 * @author diego
 * @time 2019-02-26 11:29
 * @description
 */
public abstract class AbstractInstruct implements Instruct<ChainDataObject, ResultDTO, Instruction> {

    @Autowired
    private CommonInstructInterpreter commonInstructInterpreter;
    @Autowired
    private CommonInstructInvoker commonInstructInvoker;

    protected abstract List<Field> buildField(InstructContext instructContext);

    protected abstract Table buildTable(InstructContext instructContext);

    protected abstract List<OpsField> buildFilter(InstructContext instructContext);

    protected abstract List<AggField> buildAggregation(InstructContext instructContext);

    protected abstract List<OpsField> buildAggFilter(InstructContext instructContext);

    protected abstract List<Sort> buildSort(InstructContext instructContext);


    @Override
    public Instruction instruction(ChainDataObject chainDataObject) {

    }

    @Override
    public ResultDTO invoke(ChainDataObject chainDataObject) {

    }

}
/**
 * @author diego
 * @time 2019-02-28 11:15
 * @description
 */
public class BaseInstruct extends AbstractInstruct {

    @Override
    protected List<Field> buildField(InstructContext instructContext) {

        ChainDataObject chainDataObject = instructContext.getChainDataObject();
        List<Field> fields = chainDataObject.getCols();
        return fields;
    }

    @Override
    protected Table buildTable(InstructContext instructContext) {
        return null;
    }

    @Override
    protected List<OpsField> buildFilter(InstructContext instructContext) {

        ChainDataObject chainDataObject = instructContext.getChainDataObject();
        List<OpsField> opsFields = chainDataObject.getFilter();
        return opsFields;
    }

    @Override
    protected List<AggField> buildAggregation(InstructContext instructContext) {

        List<AggField> aggFields = instructContext.getChainDataObject().getAggregation();
        return aggFields;

    }

    @Override
    protected List<OpsField> buildAggFilter(InstructContext instructContext) {
        return null;
    }

    @Override
    protected List<Sort> buildSort(InstructContext instructContext) {
        List<Sort> sorts = instructContext.getChainDataObject().getSort();
        return sorts;

    }
}

by https://blog.csdn.net/pianistofsoftware/article/details/51910605

抽象类与接口紧密相关。然接口又比抽象类更抽象,这主要体现在它们的差别上:1)类可以实现无限个接口,但仅能从一个抽象(或任何其他类型)类继承,从抽象类派生的类仍可实现接口,从而得出接口是用来解决多重继承问题的。2)抽象类当中可以存在非抽象的方法,可接口不能且它里面的方法只是一个声明必须用public来修饰没有具体实现的方法。3)抽象类中的成员变量可以被不同的修饰符来修饰,可接口中的成员变量默认的都是静态常量(static final)。4)这一点也是最重要的一点本质的一点"抽象类是对象的抽象,然接口是一种行为规范"。

不同之处:
定义// 
  抽象类表示该类中可能已经有一些方法的具体定义,但是接口就仅仅只能定义各个方法的界面(方法名,参数列表,返回类型),并不关心具体细节。
用法//
  1)在继承抽象类时,必须覆盖该类中的每一个抽象方法,而每个已实现的方法必须和抽象类中指定的方法一样,接收相同数目和类型的参数,具有同样的返回值,这一点与接口相同。
  2)当父类已有实际功能的方法时,该方法在子类中可以不必实现,直接引用的方法,子类也可以重写该父类的方法(继承的概念)。
  3)而实现 (implement)一个接口(interface)的时候,是一定要实现接口中所定义的所有方法,而不可遗漏任何一个。
  4)另外,抽象类不能产生对象的,但可以由它的实现类来声明对象。
 

在实现接口时,我们也常写一个抽象类,来实现接口中的某些子类所需的通用方法,接着在编写各个子类时,即可继承该抽象类来使用,省去在每个都要实现通用的方法的困扰。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值