#include <Free_List.h>
Inheritance diagram for ACE_Locked_Free_List< T, ACE_LOCK >:
Public Member Functions | |
ACE_Locked_Free_List (int mode=ACE_FREE_LIST_WITH_POOL, size_t prealloc=ACE_DEFAULT_FREE_LIST_PREALLOC, size_t lwm=ACE_DEFAULT_FREE_LIST_LWM, size_t hwm=ACE_DEFAULT_FREE_LIST_HWM, size_t inc=ACE_DEFAULT_FREE_LIST_INC) | |
virtual | ~ACE_Locked_Free_List (void) |
Destructor - removes all the elements from the free_list. | |
virtual void | add (T *element) |
virtual T * | remove (void) |
virtual size_t | size (void) |
Returns the current size of the free list. | |
virtual void | resize (size_t newsize) |
Resizes the free list to newsize. | |
Protected Member Functions | |
virtual void | alloc (size_t n) |
Allocates n extra nodes for the freelist. | |
virtual void | dealloc (size_t n) |
Removes and frees n nodes from the freelist. | |
Protected Attributes | |
int | mode_ |
T * | free_list_ |
Pointer to the first node in the freelist. | |
size_t | lwm_ |
Low water mark. | |
size_t | hwm_ |
High water mark. | |
size_t | inc_ |
Increment value. | |
size_t | size_ |
Keeps track of the size of the list. | |
ACE_LOCK | mutex_ |
Synchronization variable for ACE_Timer_Queue. | |
Private Member Functions | |
ACE_Locked_Free_List (const ACE_Locked_Free_List< T, ACE_LOCK > &) | |
void | operator= (const ACE_Locked_Free_List< T, ACE_LOCK > &) |
This class maintains a free list of nodes of type T. It depends on the type T having a and method. It maintains a mutex so the freelist can be used in a multithreaded program .
Definition at line 69 of file Free_List.h.
|
Constructor takes a (i.e., ACE_FREE_LIST_WITH_POOL or ACE_PURE_FREE_LIST), a count of the number of nodes to , a low and high water mark ( and ) that indicate when to allocate more nodes, an increment value () that indicates how many nodes to allocate when the list must grow. Definition at line 25 of file Free_List.cpp. References ACE_Locked_Free_List< T, ACE_LOCK >::alloc().
|
|
Destructor - removes all the elements from the free_list.
Definition at line 43 of file Free_List.cpp. References ACE_PURE_FREE_LIST, and ACE_Locked_Free_List< T, ACE_LOCK >::free_list_.
00044 { 00045 if (this->mode_ != ACE_PURE_FREE_LIST) 00046 while (this->free_list_ != 0) 00047 { 00048 T *temp = this->free_list_; 00049 this->free_list_ = this->free_list_->get_next (); 00050 delete temp; 00051 } 00052 } |
|
|
|
Inserts an element onto the free list (if it isn't past the high water mark). Implements ACE_Free_List< T >. Definition at line 59 of file Free_List.cpp. References ACE_GUARD, ACE_PURE_FREE_LIST, ACE_Locked_Free_List< T, ACE_LOCK >::free_list_, and ACE_Locked_Free_List< T, ACE_LOCK >::hwm_.
00060 { 00061 ACE_MT (ACE_GUARD (ACE_LOCK, ace_mon, this->mutex_)); 00062 00063 // Check to see that we not at the high water mark. 00064 if (this->mode_ == ACE_PURE_FREE_LIST 00065 || this->size_ < this->hwm_) 00066 { 00067 element->set_next (this->free_list_); 00068 this->free_list_ = element; 00069 this->size_++; 00070 } 00071 else 00072 delete element; 00073 } |
|
Allocates n extra nodes for the freelist.
Definition at line 128 of file Free_List.cpp. References ACE_NEW, and ACE_Locked_Free_List< T, ACE_LOCK >::free_list_. Referenced by ACE_Locked_Free_List< T, ACE_LOCK >::ACE_Locked_Free_List(), ACE_Locked_Free_List< T, ACE_LOCK >::remove(), and ACE_Locked_Free_List< T, ACE_LOCK >::resize().
00129 { 00130 for (; n > 0; n--) 00131 { 00132 T *temp = 0; 00133 ACE_NEW (temp, T); 00134 temp->set_next (this->free_list_); 00135 this->free_list_ = temp; 00136 this->size_++; 00137 } 00138 } |
|
Removes and frees n nodes from the freelist.
Definition at line 143 of file Free_List.cpp. References ACE_Locked_Free_List< T, ACE_LOCK >::free_list_. Referenced by ACE_Locked_Free_List< T, ACE_LOCK >::resize().
00144 { 00145 for (; this->free_list_ != 0 && n > 0; 00146 n--) 00147 { 00148 T *temp = this->free_list_; 00149 this->free_list_ = this->free_list_->get_next (); 00150 delete temp; 00151 this->size_--; 00152 } 00153 } |
|
|
|
Takes a element off the freelist and returns it. It creates new elements if the size is at or below the low water mark. Implements ACE_Free_List< T >. Definition at line 80 of file Free_List.cpp. References ACE_GUARD_RETURN, ACE_PURE_FREE_LIST, ACE_Locked_Free_List< T, ACE_LOCK >::alloc(), ACE_Locked_Free_List< T, ACE_LOCK >::free_list_, and ACE_Locked_Free_List< T, ACE_LOCK >::lwm_.
00081 { 00082 ACE_MT (ACE_GUARD_RETURN (ACE_LOCK, ace_mon, this->mutex_, 0)); 00083 00084 // If we are at the low water mark, add some nodes 00085 if (this->mode_ != ACE_PURE_FREE_LIST && this->size_ <= this->lwm_) 00086 this->alloc (this->inc_); 00087 00088 // Remove a node 00089 T *temp = this->free_list_; 00090 00091 if (temp != 0) 00092 { 00093 this->free_list_ = this->free_list_->get_next (); 00094 this->size_--; 00095 } 00096 00097 return temp; 00098 } |
|
Resizes the free list to newsize.
Implements ACE_Free_List< T >. Definition at line 112 of file Free_List.cpp. References ACE_GUARD, ACE_PURE_FREE_LIST, ACE_Locked_Free_List< T, ACE_LOCK >::alloc(), and ACE_Locked_Free_List< T, ACE_LOCK >::dealloc().
00113 { 00114 ACE_MT (ACE_GUARD (ACE_LOCK, ace_mon, this->mutex_)); 00115 00116 // Check if we are allowed to resize 00117 if (this->mode_ != ACE_PURE_FREE_LIST) 00118 // Check to see if we grow or shrink 00119 if (newsize < this->size_) 00120 this->dealloc (this->size_ - newsize); 00121 else 00122 this->alloc (newsize - this->size_); 00123 } |
|
Returns the current size of the free list.
Implements ACE_Free_List< T >. Definition at line 104 of file Free_List.cpp.
00105 { 00106 return this->size_; 00107 } |
|
Pointer to the first node in the freelist.
Definition at line 116 of file Free_List.h. Referenced by ACE_Locked_Free_List< T, ACE_LOCK >::add(), ACE_Locked_Free_List< T, ACE_LOCK >::alloc(), ACE_Locked_Free_List< T, ACE_LOCK >::dealloc(), ACE_Locked_Free_List< T, ACE_LOCK >::remove(), and ACE_Locked_Free_List< T, ACE_LOCK >::~ACE_Locked_Free_List(). |
|
High water mark.
Definition at line 122 of file Free_List.h. Referenced by ACE_Locked_Free_List< T, ACE_LOCK >::add(). |
|
Increment value.
Definition at line 125 of file Free_List.h. |
|
Low water mark.
Definition at line 119 of file Free_List.h. Referenced by ACE_Locked_Free_List< T, ACE_LOCK >::remove(). |
|
Free list operation mode, either ACE_FREE_LIST_WITH_POOL or ACE_PURE_FREE_LIST. Definition at line 113 of file Free_List.h. |
|
Synchronization variable for ACE_Timer_Queue.
Definition at line 131 of file Free_List.h. |
|
Keeps track of the size of the list.
Definition at line 128 of file Free_List.h. |