Facade模式的最佳实践是什么?

gui*_*le8 4 java design-patterns facade

我的代码工作正常,但我不知道我实现它的方式是否合适.基本上,我想保持模式而不违反它.

代码如下所示:

包模型(省略了setter/getters):

public class CA {
    private Integer in;
    private Integer jn;
}

public class CB {
    private Integer kn;
    private Integer ln;
}

public class CC {    
    private static CC instancia;
    private CA a;
    private CB b;

    public static CC getInstancia() {
         if(instancia == null) {
             instancia = new CC();          
         }

         return instancia; 
    }
}
Run Code Online (Sandbox Code Playgroud)

包装业务:

class CCBusiness {

    static CC c = CC.getInstancia();

    void alter(Integer input) {
        c.getCA.setIn(input);
        Integer num = c.getCB.getLn();
    }
}
Run Code Online (Sandbox Code Playgroud)

包装外观:

class FacadeOne {

void methodOne() {
    CCBusiness.alter(1);
    // And more xxBusiness.xx()
}
Run Code Online (Sandbox Code Playgroud)

真正的代码更复杂,但为了解释我的疑虑,我认为这应该有效.

在一个外观中,我调用了几个Business对象,但是一个Business(在这种情况下,CC类中的一个)可以修改其他类的属性(在这种情况下,CC中的属性)是合适的吗?我应该创建CABusiness和CBBusiness吗?

因为,据我所知,一个企业不能称之为另一个企业,所以第二个是参数化从FacadeOne接收对象(如果我创建CABusiness和CBBusiness)?

Las*_*ame 6

我想澄清一些可能会帮助您:Facade模式可以帮助您有一个单一访问点几类隐藏的门面后面,从而隐藏到外面的世界.通常这些类形成某种模块或逻辑单元.

您正在努力的是立面背后的结构及其层次结构.这很难在不了解整体情况的情况下进行分析,但从我掌握的信息中,最好有几个你的Business类,可以从外观单独调用.在Business对象之间创建交叉调用将有机会对代码进行分类.

至于最佳实践和技术,最简单的方法是绘制一个的草图,这通常会澄清很多.而且你已经在基于UML的文档的一半了.:-)

顺便说一句,避免给你的类名称,如CA,CB ......这就像命名变量a001,a002一样......说起名字对可读性做了很多!