IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> 依赖倒置如何升华架构设计 -> 正文阅读

[系统运维]依赖倒置如何升华架构设计

一、听说你是架构师不会自己写架构

百科:系统架构师是一个最终确认和评估系统需求,给出开发规范,搭建系统实现的核心构架,并澄清技术细节、扫清主要难点的技术人员。

你对核心架构有什么认识?

核心架构在软件领域是为软件系统提供结构、行为和属性的高级抽象结构。在不同领域不同业务,核心架构都关注抽象、业务规则分离。核心架构指导大型软件系统各个方面的设计。架构师在设计系统时,慎重选择各种依赖关系 - 基础框架,身份验证,存储;在规划业务战略、组建组员、项目周期、系统基础设施、调度资源都对核心架构有着重大影响。

那么,什么是架构?

架构建设的整体的认知包括三个部分:

  1. 架构为了提升生产力: 这个框架提升了我们的生产力和效率吗?是否从需求,竞争,合作方面进行了充分的思考和调研;架构的边界是否能够匹配合作的形式?是否能够让参与的各方实现共赢?
  2. 架构有时势: 时间和局势。时间包括实施的时间长短,当前业务的紧急程度;局势包括了团队的资源情况,业务的侧重点等;任何一个架构都是理想和当下的平衡。
  3. 架构来自哪些抽象思想和历史方案: 有蓝图做指导,有基础设施和资源 ,下一步就是实施和创新,实施也要考虑清楚,使用飞机还是火箭?是游艇还是航母?这些就需要在落地的时候想清楚。

二、依赖是什么?有哪些重要的具体体现?

? ? ? ? ?答案似乎很简单。如果你的系统依赖某些东西来运行,那就是一个依赖。然而,这只是冰山一角。

? ? ? ? ?更加形象的例子,动物的特征有新陈代谢,能繁殖。而要有生命力,需要氧气、水、食物等,就是说,动物依赖于氧气和水。它们之间是依赖关系,为了让软件设计人员拥有共同的交流方式,我们规定了依赖关系用虚线箭头表示。普通箭头指向被依赖的事物(例如:动物 指向氧气,指向水)。

 //通过构造函数,动物依赖于氧气、水,形成依赖关系  
  abstract class Animal {
       //新陈代谢 
    public Metabolism ( Oxygen oxygen ,Water water)
    {
    }
   }

总结:依赖关系是一种使用关系,即一个类的实现需要另一个类的协助。

表述方式:A依赖于B,A使用B

问题:如何在代码体现依赖关系,如何表达依赖?如何发现两个类(多个事物)是否存在依赖关系?在java中形成依赖关系的方式有哪些?依赖与设计原则有什么关系?

三、如何通过对依赖的认识设计业务架构呢?

依赖为什么能升华架构设计?

也许你是高手,但对依赖的问题的经历记忆深刻,反复遇到的两个事件:对象创建和对象之间的交互, 它们混合在一起,这会导致紧密耦合和不必要的依赖关系,这反过来又使维护和单元测试变得痛苦。

下面,试着用一个非常简单的例子(学生、教师、课程)来解释依赖:

class MyClass {

    private Teacher a; //A is an interface
    private Student b; //B is an interface

    //Object creation within constructor
    MyClass(Teacher  a, Student  b) {
        a = new AImpl(); //AImpl is the concrete impl of A
        b = new BImpl(); //BImpl is the concrete impl of B
    }

    //Application logic lies within this method
    public void doSomething() {
        //Do A specific thing
        //Do B specific thing
        Class c = new CImpl(); //Object creation within the method.
        //Do C specific thing
    }
}

public interface Teacher {
}
public class AImpl implements Teacher  {
}
public interface Student {
}
public class BImpl implements Student {
}
public interface Class {
}
public class CImpl implements Class {
}

这个MyClass 类的问题是:

  1. 它无法将对象创建与业务逻辑分开,从而导致紧密耦合。
  2. 这里已经完成了“编程到实现”,而不是接口。明天,如果需要 A、B 或 C 的不同实现,则必须更改类中的代码。
  3. 测试 MyClass 需要首先测试 A、B、C。

因此,每个软件设计师在设计时,都会经历测试痛苦过程,而产生对依赖的问题的经历记忆深刻。

那么, 依赖的认识已经有了,那么设计业务时候,你能从依赖 升华 设计吗?

为了深刻,可以继续思考下面的依赖的例子:



//抽象观察者,为所有的具体观察者定义一个接口,在得到主题的通知时更新自己。
abstract class AbObserver {

    public abstract void Update();//更新方法
}

//会计员同事
public class AccountantObserver {
    private  String name;
    //秘书---关联秘书
    private  Secretary sub;

    public AccountantObserver(String name,Secretary sub){
        this.name=name;
        this.sub=sub;
    }

    public void  SayUpdate(){
        //得到前台的通知,赶快行动
        String s=sub.getAction();
        System.out.printf(this.name);
        System.out.printf("工作。");
        System.out.printf("因为前台通知:");
        System.out.printf(s,sub.getAction().toString());
    }
}

//前台秘书
public class Secretary {

    //同事列表
    private LinkedHashSet<AccountantObserver> observers =new LinkedHashSet() ;


    //行为
    private  String action;

    //增加,就是有几个同事请前台帮忙,于是就给集合增加几个对象
    public  void  Attach(AccountantObserver observer){
        observers.add(observer);
    }

    //通知
    public void  Notify(){
        for (AccountantObserver o: observers) {
            o.SayUpdate();
        }
    }

    //前台秘书的工作状态---前台通过电话,说话、或所做的事情变化,
    public String getAction() {
        return action;
    }

    public void setAction(String action) {
        this.action = action;
    }



}

     //前台秘书小丽发消息
      
        Secretary xiaoli =new Secretary();

        //打游戏的会计同事
        AccountantObserver xiaogao =new AccountantObserver("小高",xiaoli);

        //喝茶的会计同事
        AccountantObserver xiaozhao =new AccountantObserver("小赵",xiaoli);

        //前台记录两位同事
        xiaoli.Attach(xiaogao);
        xiaoli.Attach(xiaozhao);

        //发现老板回来
        xiaoli.setAction("老板回来了!!!");

        //通知同事
        xiaoli.Notify();

四、伟大的DIP原则是怎么指导业务架构的实施呢?

DIP原则是面向对象编程中最着名的原则之一。这个原则提出有一段时间了,是?Robert C. Martin?于1996年制定了依赖性倒置原则(DIP)。它代表“?SOLID?”原则中的字母“?D?”。

Vaughn Vernon2013)演示了如何在典型的4层架构中应用DIP

? ? ? 为了深刻研究,继续发现:

? ? ? ?例子1:假设我们设计一套流程:先设计用户界面层,然后根据用户设计应用层,接着根据应用设计领域层,最后根据领域层设计基础设施层,并组装好整个系统依赖。这里就出现了一个“依赖”关系:该模式不指定层数,而是一个简单的规则:一层可以与其下面的任何层形成强的耦合关系,并形成简单的分层架构。从上图也明显发现,高层模块依赖底层模块,都依赖基础设施层。

? ? ? ?例子2:假设我们设计一辆汽车:先设计轮子,然后根据轮子大小设计底盘,接着根据底盘设计车身,最后根据车身设计好整个汽车。而这个设计的“依赖”关系体现在:汽车依赖车身,车身依赖底盘,底盘依赖轮子。

? ? ? ?而Vaughn Vernon2013)演示主要目标是解决分层架构的紧耦合问题。通过如图的设计,进行模块的反转,领域层是所有其他层依赖的域层。这种方法消除了与基础设施层的直接耦合。

? ? ? 通过上图分析,基于DIP的架构的好处:

  • 独立于UI
  • 独立于数据库和其他外部系统
  • 独立于技术特定的库和框架
  • 可互换的基础设施模块
  • 任意数量和类型的客户端
  • 测试简单了很多

五、你能描述清楚依赖倒置吗

? ? ? 问题1:你描述对依赖倒置的认识?

? ? ? ?这个问题,你联系我吧。

? ? ??问题2:依赖倒置的架构有什么缺点?

? ? ? ?1.不理解原理的过程和思想就会很复杂。

? ? ? ?2.术语模糊。

? ? ? ?3.易受错误依赖影响。idea中依赖项理清楚、说清楚依赖关系更加复杂。

? ? ? 4.你还会设计模式吗?你还会选择模式吗?如何选择模式?

六、如何理解依赖注入与依赖倒置的关系

? ? ? ?明天更新

? ? ??

?

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-02-09 21:08:06  更:2022-02-09 21:10:23 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 10:56:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码