潛魚在淵

          Concentrating on Architectures.

          posts - 77, comments - 309, trackbacks - 0, articles - 0
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          對象傳遞和信息完整性

          Posted on 2005-12-05 17:56 非魚 閱讀(1098) 評論(3)  編輯  收藏 所屬分類: 面向對象設計
              很少有孤立存在的實體對象,它們之間總是會有所關聯。對象們因其職責而分離,又因其聯系而聚合。而我們在使用對象時,往往不需要把對象及其聚合的所有其他 對象一次性全部初始化,部分的對象聚合足以提供足夠的信息了。這時候,我們使用的對象的信息是不完整的。

              當具有不完整信息的對象被做為參數傳遞時,很可能導致我們對對象失去控制。部分對象的聚合在不同情景下的切換可能導致編程上的錯誤,而且對系統的維護帶來 負面的影響。由于對象職責的分割,對象本身無法理解這個問題,我們無法通過對對象本身進行處理(如增加職責)來消除這種不良影響。如何使用對象的部分信息 是由使用者根據情景要求決定的,編碼人員往往對使用情景沒有深刻的認識。在連續對應不同情景的處理鏈中,容易導致編碼錯誤。如下:

           1// Entity objects.
           2public class Obj {
           3  private ObjRef1 ref1;
           4  Private ObjRef2 ref2;
           5
           6  public Obj() {
           7  }
           8
           9  public Obj(ObjRef1 ref1) {
          10    this.ref1 = ref1;
          11  }
          12
          13  public Obj(ObjRef1 ref1, ObjRef2 ref2) {
          14    this.ref1 = ref1;
          15    this.ref2 = ref2;
          16  }
          17  // Accessors omitted.
          18} // ObjRef1, ObjRef2 omitted.
          19
          20// Process1
          21public class Prs1 {
          22  public Obj method1() {
          23    Obj obj = new Obj();
          24    obj.setObjRef1(loadObjRef1());
          25    // Do something to obj.
          26    return obj;
          27  }
               // Load method omitted.
               private ObjRef1 loadObjRef1() {
                 // ......
               }
          28}
          29
          30// Process2
          31public class Prs2 {
          32  public void method2() {
          33    Obj obj = new Clt1().method1();
          34    // Do something to obj.ref2. Coding error may be found until debug phase.
          35  }
          36}

              在Process1.method1方法中持久化Obj,在Process2.method2中自行初始化Obj。這個方案面向對象并解決了一致性問題, 但增加性能成本。在Process1.method1中loadObjRef2,不夠面向對象,增加了維護成本。
             
              盡可能不使用這種鏈式的處理,代之以扁平的、可以總控Obj的方式:
             
           1public class Process {
           2  public void proceed() {
           3    // Need to change Prs1, Prs2's method signatures.
           4    Obj obj = 
           5    obj = new Prs1().method1(obj);
           6    obj.setObjRef2();
           7    obj = new Prs2().method2(obj);
           8    
           9    // Future processes can be inserted anywhere inside this method.
          10  }
          11}


              對于樹形結構或整體-部分結構,有一個統一的處理合理的,但內部的復雜性還是很高。

          評論

          # re: 對象的部分聚合問題  回復  更多評論   

          2005-12-06 10:06 by 小明
          樓主不會不知道Spring framework吧?

          Spring IOC能很好幫助你解決這個問題阿

          # re: 對象的部分聚合問題  回復  更多評論   

          2005-12-06 11:43 by 無言獨上西樓
          本質上說,IOC并沒有什么新鮮玩意,就是強化對接口編程。SPRING是提供了一個這樣的框架-裝配對象的框架,這樣,任何相同接口的對象就可以裝配在一起工作,類似于汽車裝配線。
          但顯然沒有明白LZ的意思。坦率地說,我也沒有明白LZ的意思。

          # re: 對象傳遞和信息完整性  回復  更多評論   

          2005-12-07 00:13 by 非魚
          前面描述的不好,給大家造成了理解上的麻煩。希望這次改過后表達足夠清楚。不行就再改吧。
          主站蜘蛛池模板: 嵩明县| 沙湾县| 霍林郭勒市| 江孜县| 普兰店市| 尼勒克县| 周至县| 玉环县| 都匀市| 北辰区| 兰溪市| 定南县| 江陵县| 太湖县| 蚌埠市| 大安市| 穆棱市| 侯马市| 托里县| 钦州市| 四平市| 深水埗区| 庄浪县| 岳阳县| 黎城县| 恩平市| 怀远县| 五家渠市| 峡江县| 墨玉县| 五常市| 昭觉县| 富裕县| 襄城县| 阿拉尔市| 东丽区| 绥芬河市| 定远县| 山阴县| 镇赉县| 疏附县|