zoukankan      html  css  js  c++  java
  • DI in the development CQ

    author:czy

    DI pattern (Dependency Injection) frees us from the sophisticated construction of the depended objects.

    In the business view, it helps the developers concentrate on the the business domain without any worries on the initialization of the depended objects.

    In the architecture view, it facilitates the reuse of the component as the depended objects are resolved in the DI.

    Let’s take the design of TeamView as an example.

    There is a JIRAImportControl to import the JIRA system output xml to the TeamView. The uml diagram goes as following.

    image

    From the diagram, we can see the dependency between CreateDbForm and JIRAImportControl is quite neat.

    We can easily move JIRAImportControl to another container without much more coding than let the DI construct JIRAImportControl in that container.

    However, if we give up DI, let’s see what hell would be.

    image

    Without the DI’s help, the additional dependencies come up to us. I admit that the some additional dependencies in the diagram would be a little overstated. However, if we want to resue the JIRAImportControl in another container, we have to take DBConnection construction and ItemImporterImpl construction (God bless that ItemImporterImpl would have no dependencies) into consideration. If the other container can’t supply the necessary parameters to the constructions, the design of container itself must be changed. So, the hell appears that changes happen over the system just to satisfy a little change in a little corner.

    There are many perfect DI framework, we use autofac as the DI.

    Additionally, please go to our website novasoftware for more information about the team.

  • 相关阅读:
    Pytorch版本yolov3源码阅读
    Darknet卷基层浅层特征可视化教程
    YOLOv3-darknet 内容解析
    YOLOv2-darknet 内容解析
    YOLOv1-darknet 内容解析
    Qt5.2+opencv2.4.9配置安装过程
    Android程序示例
    【Cuda编程】加法归约
    算法设计与分析课程的时间空间复杂度
    【算法分析】实验 4. 回溯法求解0-1背包等问题
  • 原文地址:https://www.cnblogs.com/czy/p/2280932.html
Copyright © 2011-2022 走看看