ObjectPool.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. using System;
  2. using System.Collections;
  3. using System.Collections.Generic;
  4. using System.Text;
  5. namespace ConnectionPool.test
  6. {
  7. public sealed class ObjectPool
  8. {
  9. private Int32 _nCapacity;
  10. private Int32 _nCurrentSize;
  11. private Hashtable _listObjects;
  12. private ArrayList _listFreeIndex;
  13. private ArrayList _listUsingIndex;
  14. private Type _typeObject;
  15. private Object _objCreateParam;
  16. public ObjectPool(Type type, Object create_param, Int32 init_size, Int32 capacity)
  17. {
  18. if (init_size < 0 || capacity < 1 || init_size > capacity)
  19. {
  20. throw (new Exception("Invalid parameter!"));
  21. }
  22. _nCapacity = capacity;
  23. _listObjects = new Hashtable(capacity);
  24. _listFreeIndex = new ArrayList(capacity);
  25. _listUsingIndex = new ArrayList(capacity);
  26. _typeObject = type;
  27. _objCreateParam = create_param;
  28. for (int i = 0; i < init_size; i++)
  29. {
  30. PoolItem pitem = new PoolItem(type, create_param);
  31. _listObjects.Add(pitem.InnerObjectHashcode, pitem);
  32. _listFreeIndex.Add(pitem.InnerObjectHashcode);
  33. }
  34. _nCurrentSize = _listObjects.Count;
  35. }
  36. public void Release()
  37. {
  38. lock (this)
  39. {
  40. foreach (DictionaryEntry de in _listObjects)
  41. {
  42. ((PoolItem)de.Value).Release();
  43. }
  44. _listObjects.Clear();
  45. _listFreeIndex.Clear();
  46. _listUsingIndex.Clear();
  47. }
  48. }
  49. public Int32 CurrentSize
  50. {
  51. get { return _nCurrentSize; }
  52. }
  53. public Int32 ActiveCount
  54. {
  55. get { return _listUsingIndex.Count; }
  56. }
  57. public Object GetOne()
  58. {
  59. lock (this)
  60. {
  61. if (_listFreeIndex.Count == 0)
  62. {
  63. if (_nCurrentSize == _nCapacity)
  64. {
  65. return null;
  66. }
  67. PoolItem pnewitem = new PoolItem(_typeObject, _objCreateParam);
  68. _listObjects.Add(pnewitem.InnerObjectHashcode, pnewitem);
  69. _listFreeIndex.Add(pnewitem.InnerObjectHashcode);
  70. _nCurrentSize++;
  71. }
  72. Int32 nFreeIndex = (Int32)_listFreeIndex[0];
  73. PoolItem pitem = (PoolItem)_listObjects[nFreeIndex];
  74. _listFreeIndex.RemoveAt(0);
  75. _listUsingIndex.Add(nFreeIndex);
  76. if (!pitem.IsValidate)
  77. {
  78. pitem.Recreate();
  79. }
  80. pitem.Using = true;
  81. return pitem.InnerObject;
  82. }
  83. }
  84. public void FreeObject(Object obj)
  85. {
  86. lock (this)
  87. {
  88. int key = obj.GetHashCode();
  89. if (_listObjects.ContainsKey(key))
  90. {
  91. PoolItem item = (PoolItem)_listObjects[key];
  92. item.Using = false;
  93. _listUsingIndex.Remove(key);
  94. _listFreeIndex.Add(key);
  95. }
  96. }
  97. }
  98. public Int32 DecreaseSize(Int32 size)
  99. {
  100. Int32 nDecrease = size;
  101. lock (this)
  102. {
  103. if (nDecrease <= 0)
  104. {
  105. return 0;
  106. }
  107. if (nDecrease > _listFreeIndex.Count)
  108. {
  109. nDecrease = _listFreeIndex.Count;
  110. }
  111. for (int i = 0; i < nDecrease; i++)
  112. {
  113. _listObjects.Remove(_listFreeIndex[i]);
  114. }
  115. _listFreeIndex.Clear();
  116. _listUsingIndex.Clear();
  117. foreach (DictionaryEntry de in _listObjects)
  118. {
  119. PoolItem pitem = (PoolItem)de.Value;
  120. if (pitem.Using)
  121. {
  122. _listUsingIndex.Add(pitem.InnerObjectHashcode);
  123. }
  124. else
  125. {
  126. _listFreeIndex.Add(pitem.InnerObjectHashcode);
  127. }
  128. }
  129. }
  130. _nCurrentSize -= nDecrease;
  131. return nDecrease;
  132. }
  133. }
  134. }