设计模式-外观模式

1.外观模式的定义及使用场景

外观模式(Facade)在开发过程中的运用频率非常高,尤其是在现阶段各个第三方SDK充斥在我们的周边,而这些SDK很大概率会使用外观模式,通过一个外观类使得整个系统的接口只有一个统一的高层接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节。

这里写图片描述

定义:

要求一个子系统的外部与其内部的通讯必须通过一个统一的对象进行。外观模式提供一个高层次的接口,使得子系统更易于使用

使用场景:

  • 为一个复杂的模块或子系统提供一个供外界访问的接口
  • 子系统相对独立–外界对子系统的访问只要黑箱操作即可
  • 预防低水平人员带来的风险扩散

    2. 外观模式的优缺点

    2.1优点

  • 减少系统的相互依赖
  • 提高了灵活性
  • 提高安全性

    2.2缺点

    门面模式的最大缺点就是不符合开闭原则,对修改关闭,对扩展开放,需求变化时,需要修改Facade的代码,这样相对风险比较大

    3.注意事项

  • 对于庞大到不能容忍的程度,一个子系统可以有多个门面
  • 门面不要参与子系统内的业务逻辑

    4. 外观模式的实现方式

    1
    2
    3
    4
    5
    public class ClassA {
    public void doSomeThing() {
    System.out.println("ClassA is doSomeThing!!!");
    }
    }
1
2
3
4
5
public class ClassB {
public void doSomeThing() {
System.out.println("ClassB is doSomeThing!!!");
}
}
1
2
3
4
5
public class ClassC {
public void doSomeThing() {
System.out.println("ClassC is doSomeThing!!!");
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
public class Facade {
ClassA classA = new ClassA();
ClassB classB = new ClassB();
ClassC classC = new ClassC();

public void doMethodA() {
classA.doSomeThing();
}

public void doMethodB() {
classB.doSomeThing();
}

public void doMethodC() {
classC.doSomeThing();
}
}
1
2
3
4
5
6
7
8
9
public class Test {

public static void main(String args[]) {
Facade facade = new Facade();
facade.doMethodA();
facade.doMethodB();
facade.doMethodC();
}
}

5. 外观模式在Android中的实际应用

在Android开发过程中,Context是最重要的一个类型,Context意为上下文,也就是程序的运行环境。它封装了很多重要的操作。如startActivity()、sendBoradcast()、bindService等,因此,Context对开发者来说就是重要的高层接口。

我们都知道Context的实现类是ContextImpl。ContextImpl内部封装了很多不同子系统的操作,例如Activity的跳转、广播、启动服务、设置壁纸等,这些工作并不是在ContextImpl中实现,而是转交给了具体的子系统进行处理。

用户可以通过Context这个接口统一进行与Android系统的交互,这样用户通过情况下就不需要对每个子系统进行了解,例如启动Activity时用户不需要手动调用mMainThread.getInstrumentation().execStartActivity函数进行执行,发送广播时也不需要直接操作ActivityManagerNative类。用户于系统服务的交互都通过Context的高层接口,这样对用户屏蔽了具体的实现细节,降低了使用成本

关于Context的具体介绍可以参考博文:
http://blog.csdn.net/junbin1011/article/details/54612858( Android之Context底层原理)