偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

設(shè)計(jì)模式之對(duì)象池模式(Object Pool Pattern)

開發(fā) 前端
對(duì)象池模式(Object Pool Pattern),是創(chuàng)建型設(shè)計(jì)模式的一種,將對(duì)象預(yù)先創(chuàng)建并初始化后放入對(duì)象池中,對(duì)象提供者就能利用已有的對(duì)象來(lái)處理請(qǐng)求,減少頻繁創(chuàng)建對(duì)象所占用的內(nèi)存空間和初始化時(shí)間。

[[437238]]

1 對(duì)象池模式的定義

對(duì)象池模式(Object Pool Pattern),是創(chuàng)建型設(shè)計(jì)模式的一種,將對(duì)象預(yù)先創(chuàng)建并初始化后放入對(duì)象池中,對(duì)象提供者就能利用已有的對(duì)象來(lái)處理請(qǐng)求,減少頻繁創(chuàng)建對(duì)象所占用的內(nèi)存空間和初始化時(shí)間。一個(gè)對(duì)象池包含一組已經(jīng)初始化并且可以使用的對(duì)象,可以在有需求時(shí)創(chuàng)建和銷毀對(duì)象。對(duì)象池的用戶可以從池子中取得對(duì)象,對(duì)其進(jìn)行操作處理,并在不需要時(shí)歸還給池子而非直接銷毀。對(duì)象池是一個(gè)特殊的工廠對(duì)象,對(duì)象池模式就是單例模式加享元模式。

2 對(duì)象池模式的應(yīng)用場(chǎng)景

對(duì)象池模式主要適用于以下應(yīng)用場(chǎng)景。

(1)資源受限的場(chǎng)景。比如,不需要可伸縮性的環(huán)境(CPU\內(nèi)存等物理資源有限),CPU性能不夠強(qiáng)勁,內(nèi)存比較緊張,垃圾收集,內(nèi)存抖動(dòng)會(huì)造成比較大的影響,需要提高內(nèi)存管理效率, 響應(yīng)性比吞吐量更為重要。

(2)在內(nèi)存中數(shù)量受限的對(duì)象。

(3)創(chuàng)建成本高的對(duì)象,可以考慮池化。

補(bǔ)充:常見的使用對(duì)象池的場(chǎng)景有在使用Socket時(shí)的各種連接池、線程池、數(shù)據(jù)庫(kù)連接池等。

3 對(duì)象池模式的UML類圖

對(duì)象池模式的UML類圖如下圖所示。

由上圖可以看到,對(duì)象池模式主要包含3個(gè)角色。

(1)對(duì)象池(ObjectPool):持有對(duì)象并提供取/還等方法。

(2)抽象池化對(duì)象(PooledObject):對(duì)池中對(duì)象的抽象。

(3)具體池化對(duì)象(ConcretePoolObject):對(duì)池中對(duì)象的封裝,封裝對(duì)象的狀態(tài)和一些其他信息。

4 對(duì)象池模式的通用寫法

以下是對(duì)象池模式的通用寫法。

  1. public class Client { 
  2.  
  3.     public static void main(String[] args) { 
  4.         ObjectPool pool = new ObjectPool(10,50); 
  5.         IPooledObject object = pool.borrowObject(); 
  6.         object.operation(); 
  7.         pool.returnObject(object); 
  8.         System.out.println(); 
  9.     } 
  10.  
  11.     //抽象對(duì)象 
  12.     interface IPooledObject { 
  13.         void operation(); 
  14.     } 
  15.     //具體對(duì)象 
  16.     static class ConcretePoolObject implements IPooledObject { 
  17.         public void operation() { 
  18.             System.out.println("doing"); 
  19.         } 
  20.     } 
  21.  
  22.     //對(duì)象池 
  23.     static class ObjectPool { 
  24.         private int step = 10;                      //當(dāng)對(duì)象不夠用的時(shí)候,每次擴(kuò)容的數(shù)量 
  25.         private int minCount; 
  26.         private int maxCount; 
  27.         private Vector<IPooledObject> returneds;     //保存未借出的對(duì)象 
  28.         private Vector<IPooledObject> borroweds;     //保存已被借出的對(duì)象 
  29.  
  30.         //初始化對(duì)象池 
  31.         public ObjectPool(int minCount,int maxCount){ 
  32.             borroweds = new Vector<IPooledObject>(); 
  33.             returneds = new Vector<IPooledObject>(); 
  34.  
  35.             this.minCount = minCount; 
  36.             this.maxCount = maxCount; 
  37.  
  38.             refresh(this.minCount); 
  39.         } 
  40.  
  41.         //因?yàn)閮?nèi)部狀態(tài)具備不變性,所以作為緩存的鍵 
  42.         public IPooledObject borrowObject() { 
  43.             IPooledObject next = null
  44.             if(returneds.size() > 0){ 
  45.                 Iterator<IPooledObject> i = returneds.iterator(); 
  46.                 while (i.hasNext()){ 
  47.                     next = i.next(); 
  48.                     returneds.remove(next); 
  49.                     borroweds.add(next); 
  50.                     return next
  51.                 } 
  52.             }else
  53.                 //計(jì)算出剩余可創(chuàng)建的對(duì)象數(shù) 
  54.                 int count = (maxCount - minCount); 
  55.                 //剩余可創(chuàng)建的數(shù)量大于單次固定創(chuàng)建的對(duì)象數(shù) 
  56.                 //則再初始化一批固定數(shù)量的對(duì)象 
  57.                 refresh(count > step ? step : count); 
  58.             } 
  59.             return next
  60.         } 
  61.  
  62.         //不需要使用的對(duì)象歸還重復(fù)利用 
  63.         public void returnObject(IPooledObject pooledObject){ 
  64.             returneds.add(pooledObject); 
  65.             if(borroweds.contains(pooledObject)){ 
  66.                 borroweds.remove(pooledObject); 
  67.             } 
  68.         } 
  69.  
  70.         private void refresh(int count){ 
  71.             for (int i = 0; i < count; i++) { 
  72.                 returneds.add(new ConcretePoolObject()); 
  73.             } 
  74.         } 
  75.     } 

對(duì)象池模式和享元模式的最大區(qū)別在于,對(duì)象池模式中會(huì)多一個(gè)回收對(duì)象重復(fù)利用的方法。所以,對(duì)象池模式應(yīng)該是享元模式更加具體的一個(gè)應(yīng)用場(chǎng)景。相當(dāng)于先將對(duì)象從對(duì)象池中借出,用完之后再還回去,以此保證有限資源的重復(fù)利用。

5 對(duì)象池模式的優(yōu)點(diǎn)

復(fù)用池中對(duì)象,消除創(chuàng)建對(duì)象、回收對(duì)象所產(chǎn)生的內(nèi)存開銷、CPU開銷,以及跨網(wǎng)絡(luò)產(chǎn)生的網(wǎng)絡(luò)開銷。

6 對(duì)象池模式的缺點(diǎn)

(1)增加了分配/釋放對(duì)象的開銷。

(2)在并發(fā)環(huán)境中,多個(gè)線程可能(同時(shí))需要獲取池中對(duì)象,進(jìn)而需要在堆數(shù)據(jù)結(jié)構(gòu)上進(jìn)行同步或者因?yàn)殒i競(jìng)爭(zhēng)而產(chǎn)生阻塞,這種開銷要比創(chuàng)建銷毀對(duì)象的開銷高數(shù)百倍。

(3)由于池中對(duì)象的數(shù)量有限,勢(shì)必成為一個(gè)可伸縮性瓶頸。

(4)很難合理設(shè)定對(duì)象池的大小,如果太小,則起不到作用;如果過(guò)大,則占用內(nèi)存資源高。

 

責(zé)任編輯:姜華 來(lái)源: Tom彈架構(gòu)
相關(guān)推薦

2021-12-01 07:38:27

設(shè)計(jì)模式規(guī)格模式Specificati

2019-08-16 10:46:46

JavaScript工廠模式抽象工廠模式

2013-05-23 15:59:00

線程池

2021-07-07 10:31:19

對(duì)象池模式解釋器模式設(shè)計(jì)模式

2024-07-31 10:41:16

C#設(shè)計(jì)模式

2020-08-21 07:23:50

工廠模式設(shè)計(jì)

2012-08-22 10:10:25

單態(tài)單態(tài)設(shè)計(jì)設(shè)計(jì)模式

2021-06-09 08:53:34

設(shè)計(jì)模式策略模式工廠模式

2012-02-29 09:41:14

JavaScript

2012-01-13 15:59:07

2015-09-08 13:39:10

JavaScript設(shè)計(jì)模式

2021-12-24 07:50:45

責(zé)任鏈模式設(shè)計(jì)

2023-09-04 13:14:00

裝飾器設(shè)計(jì)模式

2021-06-29 08:54:23

設(shè)計(jì)模式代理模式遠(yuǎn)程代理

2021-06-16 08:56:06

模版方法模式設(shè)計(jì)模式行為型設(shè)計(jì)模式

2024-02-19 08:38:34

建造者模式Android設(shè)計(jì)模式

2024-04-16 00:07:36

設(shè)計(jì)模式代理模式替身

2020-12-01 07:16:05

重學(xué)設(shè)計(jì)模式

2021-01-21 05:34:14

設(shè)計(jì)模式建造者

2021-03-05 07:57:41

設(shè)計(jì)模式橋接
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)