创新设计模式:原型模式
原型模式用于創(chuàng)建對(duì)象的副本。 這種模式非常有用,特別是當(dāng)從頭開(kāi)始創(chuàng)建對(duì)象的成本很高時(shí)。
與builder , factory和abstract factory模式相比,它不會(huì)從頭開(kāi)始創(chuàng)建對(duì)象,而是會(huì)克隆/重新創(chuàng)建它。 與單例模式相比,它創(chuàng)建一個(gè)實(shí)例的多個(gè)副本,而單例必須確保只有一個(gè)副本存在。
想象一下一個(gè)對(duì)象的場(chǎng)景,要?jiǎng)?chuàng)建該對(duì)象需要非常耗費(fèi)資源的方法。 它可以是具有許多聯(lián)接的數(shù)據(jù)庫(kù)查詢(xún),甚至可以是聯(lián)合搜索的結(jié)果。
我們希望這些數(shù)據(jù)通過(guò)各種算法使用一種算法處理一個(gè)線程。 每個(gè)線程應(yīng)具有其自己的原始實(shí)例副本,因?yàn)槭褂猛粚?duì)象將導(dǎo)致結(jié)果不一致。
因此,我們有一個(gè)表示搜索結(jié)果的接口。
package com.gkatzioura.design.creational.prototype;public interface SearchResult {SearchResult clone();int totalEntries();String getPage(int page); }并且我們將FederatedSearchResult實(shí)現(xiàn)為SearchResult。
package com.gkatzioura.design.creational.prototype;import java.util.ArrayList; import java.util.List;public class FederatedSearchResult implements SearchResult {private List<String> pages = new ArrayList<String>();public FederatedSearchResult(List<String> pages) {this.pages = pages;}@Overridepublic SearchResult clone() {final List<String> resultCopies = new ArrayList<String>();pages.forEach(p->resultCopies.add(p));FederatedSearchResult federatedSearchResult = new FederatedSearchResult(resultCopies);return federatedSearchResult;}@Overridepublic int totalEntries() {return pages.size();}@Overridepublic String getPage(int page) {return pages.get(page);} }因此,我們可以使用clone方法并根據(jù)需要?jiǎng)?chuàng)建一個(gè)非常昂貴的對(duì)象的數(shù)量創(chuàng)建多個(gè)副本。
您可以在github上找到源代碼。
另外,我還編寫(xiě)了備忘單,其中包含“創(chuàng)作設(shè)計(jì)模式”的摘要。 在鏈接中注冊(cè)以接收它。
翻譯自: https://www.javacodegeeks.com/2018/03/creational-design-patterns-prototype-pattern.html
總結(jié)
以上是生活随笔為你收集整理的创新设计模式:原型模式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 复杂 PPT 图表的简化
- 下一篇: 创新设计模式:单例模式