• 为什么尽量少用继承?


    1、继承的缺点是什么?为什么不推荐使用继承?

    如果滥用继承,会导致继承层次过深,复杂的继承关系。导致维护性降低。(如果继承关系层次少,不fu)
    (继承是面向对象的四大特性之一,用来表示类之间的 is-a 关系,可以解决代码复用的问
    题。虽然继承有诸多作用,但继承层次过深、过复杂,也会影响到代码的可维护性。在这种
    情况下,我们应该尽量少用,甚至不用继承。)

    2、我们有什么手段可以替代继承呢?

    可以用组合,接口,委托来实现。我们下看看下面的代码:

    public interface Flyable {
    void fly();
    }
    public class FlyAbility implements Flyable {
    @Override
    public void fly() { //... }
    }
    // 省略 Tweetable/TweetAbility/EggLayable/EggLayAbility
    public class Ostrich implements Tweetable, EggLayable {// 鸵鸟
    private TweetAbility tweetAbility = new TweetAbility(); // 组合
    private EggLayAbility eggLayAbility = new EggLayAbility(); // 组合
    //... 省略其他属性和方法...
    @Override
    public void tweet() {
    tweetAbility.tweet(); // 委托
    }
    @Override
    public void layEgg() {
    eggLayAbility.layEgg(); // 委托
    }
    }
    

    3、 组合相比继承有哪些优势?

    继承主要有三个作用,表示is-a关系,支持多态特性,代码复用。而这三个作用都可以通过组合、接口、委托三个技术手段来达成。
    除此之外,利用组合还能解决层次过深,过复杂的继承关系影响代码可维护性

    4、如何判断该用组合还是继承?

    如果类之间的继承结构稳定,层次比较浅,关系不复杂,我们就可以大胆地使用继承。
    反之,我们就尽量使用组合来替代继承。除此之外,还有一些设计模式,特殊的应用场景,会固定使用继承或者组合

    5、有人极力不使用继承,原因是什么?

    1. 人无法预知未来,现在比较稳定的类继承关系将来未必稳定。
      2.两种设计之间的选择耗费资源,每次都要为这个问题拿捏一下,甚至争论一下,不如把
      争论放在业务逻辑的实现上。
      3.相对于接口+组合+委托增加的复杂度,代码统一成接口+组合+委托带来的好处更多,

    GO完全摒弃了继承,在语法上只有组合,接口之间也可以组合(这也是官方鼓励的做法)。

    问题:
    我们在基于 MVC 架构开发 Web 应用的时候,经常会在数据库层定义 Entity,在 Service业务层定义 BO(Business Object),在 Controller 接口层定义 VO(View Object)。大部分情况下,Entity、BO、VO 三者之间的代码有很大重复,但又不完全相同。我们该如何处理 Entity、BO、VO 代码重复的问题呢?

    VO和BO都会采用组合entity的方式

  • 相关阅读:
    C语言 · 最大最小值
    C语言 · 三个整数的排序
    C语言 · 简单加法
    C语言 · FJ的字符串
    C语言 · 分解质因数
    C语言 · 数的统计
    C语言 · 成绩的等级输出
    C语言 · 区间K大数查询
    shell学习目录
    数据库学习目录
  • 原文地址:https://www.cnblogs.com/vingLiu/p/12878257.html
Copyright © 2020-2023  润新知