美文网首页APP开发实战
APP开发实战51-APP架构设计

APP开发实战51-APP架构设计

作者: xjbclz | 来源:发表于2016-06-12 22:18 被阅读124次

    15 APP架构设计

    15.1基本原则

    (1)逐层调用原则及单向调用原则

    现在约定将N层架构的各层依次编号为1、2、…、K、…、N-1、N,其中层的编号越大,则越处在上层。那么,我们设计的架构应该满足以下两个原则:

    (a)第K(1

    (b)如果P层依赖Q层,则P的编号一定大于Q。

    其中第一个原则,保证了依赖的逐层性,及整个架构的依赖是逐层向下的,而不能跨层依赖。第二个原则,则保证了依赖的单向性,及只能上层依赖底层,而不能底层反过来依赖上层。

    (2)针对接口编程,而不是针对实现编程

    这里所指的接口,不是特指编程语言中的具体语言元素,而是指一种抽象的,在语义层面上起着接合作用语义体。它的具体实现,可能是接口,可能是抽象类,甚至可能是具体类。

    具体到N层架构中,针对接口编程的意义在部分上是这样的:

    现仍约定将N层架构的各层依次编号为1、2、…、K、…、N-1、N,其中层的编号越大,则越处在上层,那么第K层不应该依赖具体一个K-1层,而应该依赖一个K-1层的接口,即在第K层中不应该有K-1层中的某个具体类。

    (3)依赖倒置原则

    在软件设计原则中,有一种重要的思想叫做依赖倒置。它的核心思想是:不能让高层组件依赖底层组件,而且,不管高层组件和底层组件,两者都应依赖于抽象。

    具体依赖——如果P层中有一个或一个以上的地方实例化了Q层中某个具体类,则说P层具体依赖于Q层。

    抽象依赖——如果P层没有实例化Q层中的具体类,而是在一个或一个以上的地方实例化了Q层中某个接口,则说P层抽象依赖于Q层,也叫接口依赖于Q层。

    从这两个定义可以看到,所谓的依赖倒置原则,正是上面提到针对接口编程,而不是针对实现编程,两者在本质上是统一的。

    (4)封装变化原则

    封装变化的原则定义为:找出应用中可能需要变化之处,把它们独立出来,不要和那些不需要变化的代码混杂在一起。

    (5)开放-关闭原则

    开发-关闭原则定义为:对扩展开放,对修改关闭。

    具体到N层架构中,可以描述为:当某一层有了一个新的具体实现时,它应该可以在不修改其他层的情况下,与此新实现无缝连接,顺利交互。

    (6)单一归属原则

    在这个架构中,任何一个操作类都应该有单一的职责,属于单独的一层,而不能同时担负两种职责或属于多个层次。

    (实体类及辅助类可以被多个层使用,但它们不属于任何一个层,而是独立存在)

    相关文章

      网友评论

        本文标题:APP开发实战51-APP架构设计

        本文链接:https://www.haomeiwen.com/subject/nexydttx.html