EJB設計模式4 (轉)
EJB設計模式4 (轉)[@more@]
在設計模式3中我們看到使bean從struct繼承後使得程式碼大
幅縮水並且所有的欄位都可定義為cmp欄位。這裡,我們可
以更進一步修正setdata()和getdata()的實現方法來減少程式碼量。
我們為這個struct增加一個方法。
Value code snippet for Company
public class CompanyStruct implements
.io.Serializable {
public Integer comId;
public String comName;
public String comDescription;
public Timestamp mutationDate;
public void copyFrom(CompanyStruct struct) {
comId = struct.comId;
comName = struct.comName;
comDescription = struct.comDescription;
mutationDate = struct.mutationDate;
}
}
由於entity bean是從struct繼承下來的,在bean的實現類
中也一樣可以引用copyfrom()方法,當然,必須注意的是,
這個copyfrom()方法並不是一個商業方法,它不需要在bean
的介面中暴露給者。
現在,getdata()和setdata()方法可以簡化更進一步的簡化。
Code snippet for an Entity Bean’s getData()
public CompanyStruct getData() {
CompanyStruct result = new CompanyStruct();
result.copyFrom(this);
return result;
}
這裡把this作為一個引數傳入copyfrom()。由於enttity bean
從struct繼承而來,於是這個entitty bean便可以作為一個
struct傳入。
容器並不贊成把this指標作為一個引數傳遞因為在兩個控
制執行緒中同時訪問一個bean的例項可能會引起事務衝突。但事
實上我們所做的並沒有違背這個原則,因為我們的並沒有在
bean之間傳遞this的引用並且也沒有引用任何可能引起事務衝突的方法。
Code snippet for an Entity Bean’s setData()
public void setData(CompanyStruct struct) {
this.copyFrom(struct);
}
類似的,上面的方法把struct的值賦給enttity bean。
對於一個對映到有很多列的表的entity bean,這種實現
方法的優點是使得bean實現類的程式碼非常簡單。這種設
計模式使得程式碼及其精簡,可讀性和可維護性也大大增強。
任何的修改都只需要修改作為基類的struct,而幾
乎不需要修改bean的程式碼。把這種改變從struct分離出來,
當cmp欄位發生改變時需要修改部署描述符。這就使得開
發時能夠更好的適應設計的改變。
這裡,還是沒有實現bean之間的關係,這將在設計模式5中解決。
設計4
在設計模式3中我們看到使bean從struct繼承後使得程式碼大
幅縮水並且所有的欄位都可定義為cmp欄位。這裡,我們可
以更進一步修正setdata()和getdata()的實現方法來減少程式碼量。
我們為這個struct增加一個方法。
Value code snippet for Company
public class CompanyStruct implements
.io.Serializable {
public Integer comId;
public String comName;
public String comDescription;
public Timestamp mutationDate;
public void copyFrom(CompanyStruct struct) {
comId = struct.comId;
comName = struct.comName;
comDescription = struct.comDescription;
mutationDate = struct.mutationDate;
}
}
由於entity bean是從struct繼承下來的,在bean的實現類
中也一樣可以引用copyfrom()方法,當然,必須注意的是,
這個copyfrom()方法並不是一個商業方法,它不需要在bean
的介面中暴露給者。
現在,getdata()和setdata()方法可以簡化更進一步的簡化。
Code snippet for an Entity Bean’s getData()
public CompanyStruct getData() {
CompanyStruct result = new CompanyStruct();
result.copyFrom(this);
return result;
}
這裡把this作為一個引數傳入copyfrom()。由於enttity bean
從struct繼承而來,於是這個entitty bean便可以作為一個
struct傳入。
容器並不贊成把this指標作為一個引數傳遞因為在兩個控
制執行緒中同時訪問一個bean的例項可能會引起事務衝突。但事
實上我們所做的並沒有違背這個原則,因為我們的並沒有在
bean之間傳遞this的引用並且也沒有引用任何可能引起事務衝突的方法。
Code snippet for an Entity Bean’s setData()
public void setData(CompanyStruct struct) {
this.copyFrom(struct);
}
類似的,上面的方法把struct的值賦給enttity bean。
對於一個對映到有很多列的表的entity bean,這種實現
方法的優點是使得bean實現類的程式碼非常簡單。這種設
計模式使得程式碼及其精簡,可讀性和可維護性也大大增強。
任何的修改都只需要修改作為基類的struct,而幾
乎不需要修改bean的程式碼。把這種改變從struct分離出來,
當cmp欄位發生改變時需要修改部署描述符。這就使得開
發時能夠更好的適應設計的改變。
這裡,還是沒有實現bean之間的關係,這將在設計模式5中解決。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752043/viewspace-990199/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- EJB設計模式5 (轉)設計模式
- EJB設計模式2 (轉)設計模式
- EJB設計模式3 (轉)設計模式
- EJB設計模式1 (轉)設計模式
- EJB設計模式之Data Transfer Object (轉)設計模式Object
- EJB設計模式(第二版)之EJB Command (轉)設計模式
- EJB 程式設計模型 (轉)程式設計模型
- 尋書---<<ejb設計模式>>設計模式
- 設計模式-策略模式(轉)設計模式
- 設計模式 | 4分鐘搞懂10種設計模式設計模式
- Java設計模式4:單例模式Java設計模式單例
- 玩轉設計模式——設計模式之禪設計模式
- 4/24 設計模式之命令設計模式 Command Pattern設計模式
- 設計模式—單例模式(轉)設計模式單例
- 設計模式【4】-- 建造者模式詳解設計模式
- javascript設計模式 之 4 迭代器模式JavaScript設計模式
- 23種設計模式(4)-原型模式設計模式原型
- 《設計模式 》 - 4. 原型模式( Prototype )設計模式原型
- 設計模式系列4--生成器模式設計模式
- C#設計模式(4)——抽象工廠模式C#設計模式抽象
- 設計模式 #4 (裝飾器模式、介面卡模式)設計模式
- jsp設計模式(轉)JS設計模式
- JAVA設計模式 4【建立型】理解建造者模式Java設計模式
- PHP設計模式(4)—— 資料物件對映模式PHP設計模式物件
- 怎麼使用EJB來達到singleton模式 (轉)模式
- Delphi設計模式-Abstract Factory (轉)設計模式
- Jive 中的設計模式 (轉)設計模式
- Typescript玩轉設計模式 之 建立型模式TypeScript設計模式
- 設計模式、用Delphi描述-->Visitor模式 (轉)設計模式
- 設計模式、用Delphi描述-->Factory Method模式 (轉)設計模式
- 設計模式、用Delphi描述-->Abstract Factory模式 (轉)設計模式
- 設計模式、用Delphi實現---->Builder模式 (轉)設計模式UI
- 請斑竹及眾高手:關於EJB,同時使用JIVE中的設計模式。。。設計模式
- 《JavaScript設計模式與開發實踐》模式篇(4)—— 迭代器模式JavaScript設計模式
- 【趣味設計模式系列】之【代理模式4--ASM框架解析】設計模式ASM框架
- 設計模式的征途—4.抽象工廠(Abstract Factory)模式設計模式抽象
- 大話設計模式讀書筆記4——模版方法模式設計模式筆記
- 玩轉 iOS 開發:《iOS 設計模式 — 代理模式》iOS設計模式