|
| ACE_Hash_Map_Manager (ACE_Allocator *table_alloc=0, ACE_Allocator *entry_alloc=0) |
|
| ACE_Hash_Map_Manager (size_t size, ACE_Allocator *table_alloc=0, ACE_Allocator *entry_alloc=0) |
|
int | equal (const EXT_ID &id1, const EXT_ID &id2) |
|
u_long | hash (const EXT_ID &ext_id) |
|
| ACE_Hash_Map_Manager_Ex (ACE_Allocator *table_alloc=0, ACE_Allocator *entry_alloc=0) |
|
| ACE_Hash_Map_Manager_Ex (size_t size, ACE_Allocator *table_alloc=0, ACE_Allocator *entry_alloc=0) |
|
int | open (size_t size=ACE_DEFAULT_MAP_SIZE, ACE_Allocator *table_alloc=0, ACE_Allocator *entry_alloc=0) |
|
int | close (void) |
|
int | unbind_all (void) |
| Removes all the entries in the ACE_Hash_Map_Manager_Ex. More...
|
|
| ~ACE_Hash_Map_Manager_Ex (void) |
| Cleanup the ACE_Hash_Map_Manager_Ex. More...
|
|
int | bind (const EXT_ID &item, const INT_ID &int_id) |
|
int | bind (const EXT_ID &ext_id, const INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | trybind (const EXT_ID &ext_id, INT_ID &int_id) |
|
int | trybind (const EXT_ID &ext_id, INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id, INT_ID &old_int_id) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id, INT_ID &old_int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id, EXT_ID &old_ext_id, INT_ID &old_int_id) |
|
int | rebind (const EXT_ID &ext_id, const INT_ID &int_id, EXT_ID &old_ext_id, INT_ID &old_int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | find (const EXT_ID &ext_id, INT_ID &int_id) const |
|
int | find (const EXT_ID &ext_id) const |
| Returns 0 if the ext_id is in the mapping, otherwise -1. More...
|
|
int | find (const EXT_ID &ext_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) const |
|
void | find (EXT_ID const &ext_id, iterator &pos) const |
|
int | unbind (const EXT_ID &ext_id) |
|
int | unbind (const EXT_ID &ext_id, INT_ID &int_id) |
|
int | unbind (ACE_Hash_Map_Entry< EXT_ID, INT_ID > *entry) |
| Remove entry from map. More...
|
|
int | unbind (iterator pos) |
| Remove entry from map pointed to by iterator pos. More...
|
|
size_t | current_size (void) const |
|
size_t | total_size (void) const |
|
ACE_LOCK & | mutex (void) |
|
void | dump (void) const |
| Dump the state of an object. More...
|
|
iterator | begin (void) |
| Return forward iterator. More...
|
|
const_iterator | begin (void) const |
|
iterator | end (void) |
|
const_iterator | end (void) const |
|
reverse_iterator | rbegin (void) |
| Return reverse iterator. More...
|
|
const_reverse_iterator | rbegin (void) const |
|
reverse_iterator | rend (void) |
|
const_reverse_iterator | rend (void) const |
|
|
typedef EXT_ID | KEY |
|
typedef INT_ID | VALUE |
|
typedef ACE_LOCK | lock_type |
|
typedef ACE_Hash_Map_Entry< EXT_ID, INT_ID > | ENTRY |
|
typedef ACE_Hash_Map_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | ITERATOR |
|
typedef ACE_Hash_Map_Const_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | CONST_ITERATOR |
|
typedef ACE_Hash_Map_Reverse_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | REVERSE_ITERATOR |
|
typedef ACE_Hash_Map_Const_Reverse_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | CONST_REVERSE_ITERATOR |
|
typedef ACE_Hash_Map_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | iterator |
|
typedef ACE_Hash_Map_Const_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | const_iterator |
|
typedef ACE_Hash_Map_Reverse_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | reverse_iterator |
|
typedef ACE_Hash_Map_Const_Reverse_Iterator_Ex< EXT_ID, INT_ID, ACE_Hash< EXT_ID >, ACE_Equal_To< EXT_ID >, ACE_LOCK > | const_reverse_iterator |
|
typedef EXT_ID | key_type |
|
typedef INT_ID | data_type |
|
typedef ACE_Hash_Map_Entry< EXT_ID, INT_ID > | value_type |
|
typedef value_type & | reference |
|
typedef value_type const & | const_reference |
|
typedef value_type * | pointer |
|
typedef value_type const * | const_pointer |
|
typedef ptrdiff_t | difference_type |
|
typedef size_t | size_type |
|
int | equal (const EXT_ID &id1, const EXT_ID &id2) |
|
u_long | hash (const EXT_ID &ext_id) |
|
int | bind_i (const EXT_ID &ext_id, const INT_ID &int_id) |
| Performs bind. Must be called with locks held. More...
|
|
int | bind_i (const EXT_ID &ext_id, const INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
| Performs bind. Must be called with locks held. More...
|
|
int | trybind_i (const EXT_ID &ext_id, INT_ID &int_id) |
| Performs trybind. Must be called with locks held. More...
|
|
int | trybind_i (const EXT_ID &ext_id, INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
| Performs trybind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id) |
| Performs rebind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
| Performs rebind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id, INT_ID &old_int_id) |
| Performs rebind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id, INT_ID &old_int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
| Performs rebind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id, EXT_ID &old_ext_id, INT_ID &old_int_id) |
| Performs rebind. Must be called with locks held. More...
|
|
int | rebind_i (const EXT_ID &ext_id, const INT_ID &int_id, EXT_ID &old_ext_id, INT_ID &old_int_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
| Performs rebind. Must be called with locks held. More...
|
|
int | find_i (const EXT_ID &ext_id, INT_ID &int_id) |
|
int | find_i (const EXT_ID &ext_id) |
|
int | find_i (const EXT_ID &ext_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry) |
|
int | unbind_i (const EXT_ID &ext_id, INT_ID &int_id) |
| Performs unbind. Must be called with locks held. More...
|
|
int | unbind_i (const EXT_ID &ext_id) |
| Performs unbind. Must be called with locks held. More...
|
|
int | unbind_i (ACE_Hash_Map_Entry< EXT_ID, INT_ID > *entry) |
| Performs unbind. Must be called with locks held. More...
|
|
int | create_buckets (size_t size) |
|
int | close_i (void) |
|
int | unbind_all_i (void) |
|
int | shared_find (const EXT_ID &ext_id, ACE_Hash_Map_Entry< EXT_ID, INT_ID > *&entry, size_t &loc) |
| Returns the ACE_Hash_Map_Entry that corresponds to ext_id. More...
|
|
ACE_Hash_Map_Entry< EXT_ID, INT_ID > * | table (void) |
| Accessor of the underlying table. More...
|
|
ACE_Allocator * | table_allocator_ |
|
ACE_Allocator * | entry_allocator_ |
|
ACE_LOCK | lock_ |
|
ACE_Hash< EXT_ID > | hash_key_ |
| Function object used for hashing keys. More...
|
|
ACE_Equal_To< EXT_ID > | compare_keys_ |
| Function object used for comparing keys. More...
|
|
template<class EXT_ID, class INT_ID, class ACE_LOCK>
class ACE_Hash_Map_Manager< EXT_ID, INT_ID, ACE_LOCK >
Wrapper for backward compatibility.
This implementation of a map uses a hash table. This class expects that the <EXT_ID> contains a method called <hash>. In addition, the <EXT_ID> must support <operator==>. Both of these constraints can be alleviated via template specialization, as shown in the $ACE_ROOT/tests/Conn_Test.cpp test.
Requirements and Performance Characteristics
- Internal Structure Hash Table
- Duplicates allowed? No
- Random access allowed? Yes
- Search speed O(1)
- Insert/replace speed O(1), can be longer if the hash map has to resize
- Iterator still valid after change to container? Yes
- Frees memory for removed elements? Yes
- Items inserted by Value
- Requirements for key type
- Default constructor
- Copy constructor
- operator=
- operator==
- Requirements for object type
- Default constructor
- Copy constructor
- operator=
- operator<