#include <Containers_T.h>
Collaboration diagram for ACE_Bounded_Stack:

| Public Methods | |
| ACE_Bounded_Stack (size_t size) | |
| Initialize and allocate space for a new Bounded_Stack with the provided size. More... | |
| ACE_Bounded_Stack (const ACE_Bounded_Stack< T > &s) | |
| Initialize the stack to be an exact copy of the Bounded_Stack provided as a parameter. More... | |
| void | operator= (const ACE_Bounded_Stack< T > &s) | 
| Perform a deep copy operation using the Bounded_Stack parameter. More... | |
| ~ACE_Bounded_Stack (void) | |
| Deallocate the memory used by the Bounded_Stack. More... | |
| int | push (const T &new_item) | 
| Place a new item on top of the stack. More... | |
| int | pop (T &item) | 
| Remove and return the top stack item. More... | |
| int | top (T &item) const | 
| Return top stack item without removing it. More... | |
| int | is_empty (void) const | 
| Performs constant time check to determine if the stack is empty. More... | |
| int | is_full (void) const | 
| Performs constant time check to determine if the stack is at capacity. More... | |
| size_t | size (void) const | 
| Return the number of items currently in the stack. More... | |
| void | dump (void) const | 
| Dump the state of an object. More... | |
| Public Attributes | |
| ACE_ALLOC_HOOK_DECLARE | |
| Declare the dynamic allocation hooks. More... | |
| Private Attributes | |
| size_t | size_ | 
| Size of the dynamically allocated data. More... | |
| size_t | top_ | 
| Keeps track of the current top of stack. More... | |
| T * | stack_ | 
| Holds the stack's contents. More... | |
This implementation of a Stack uses a bounded array that is allocated dynamically. The Stack interface provides the standard constant time push, pop, and top operations.
Requirements and Performance Characteristics
| 
 | ||||||||||
| Initialize and allocate space for a new Bounded_Stack with the provided size. 
 | 
| 
 | ||||||||||
| Initialize the stack to be an exact copy of the Bounded_Stack provided as a parameter. 
 | 
| 
 | ||||||||||
| Deallocate the memory used by the Bounded_Stack. 
 | 
| 
 | ||||||||||
| Dump the state of an object. 
 | 
| 
 | ||||||||||
| Performs constant time check to determine if the stack is empty. 
 | 
| 
 | ||||||||||
| Performs constant time check to determine if the stack is at capacity. 
 | 
| 
 | ||||||||||
| Perform a deep copy operation using the Bounded_Stack parameter. If the capacity of the lhs isn't sufficient for the rhs, then the underlying data structure will be reallocated to accomadate the larger number of elements. | 
| 
 | ||||||||||
| Remove and return the top stack item. Returns -1 if the stack is already empty, 0 if the stack is not already empty, and -1 if failure occurs. | 
| 
 | ||||||||||
| Place a new item on top of the stack. Returns -1 if the stack is already full, 0 if the stack is not already full, and -1 if failure occurs. | 
| 
 | ||||||||||
| Return the number of items currently in the stack. 
 | 
| 
 | ||||||||||
| Return top stack item without removing it. Returns -1 if the stack is already empty, 0 if the stack is not already empty, and -1 if failure occurs. | 
| 
 | |||||
| Declare the dynamic allocation hooks. 
 | 
| 
 | |||||
| Size of the dynamically allocated data. 
 | 
| 
 | |||||
| Holds the stack's contents. 
 | 
| 
 | |||||
| Keeps track of the current top of stack. 
 | 
 1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001
1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001