#include <coherence/util/WrapperCollections.hpp>
Inherited by ConverterCollections::ConverterMap, and TypedCollections::TypedMap.
Public Types | ||||||||||
typedef spec::Handle | Handle | |||||||||
AbstractWrapperMap Handle definition. | ||||||||||
typedef spec::View | View | |||||||||
AbstractWrapperMap View definition. | ||||||||||
typedef spec::Holder | Holder | |||||||||
AbstractWrapperMap Holder definition. | ||||||||||
Public Member Functions | ||||||||||
virtual size32_t | size () const | |||||||||
Return the number of key-value mappings in this map.
| ||||||||||
virtual bool | isEmpty () const | |||||||||
Return true if this map contains no key-value mappings.
| ||||||||||
virtual bool | containsKey (Object::View vKey) const | |||||||||
Return true if this map contains a mapping for the specified key.
| ||||||||||
virtual bool | containsValue (Object::View vValue) const | |||||||||
Return true if this map maps one or more keys to the specified value.
This operation will probably require time linear in the map size for most implementations of the
| ||||||||||
virtual Object::Holder | get (Object::View vKey) const | |||||||||
Return the value to which this map maps the specified key.
Return
| ||||||||||
virtual Object::Holder | get (Object::View vKey) | |||||||||
Return the value to which this map maps the specified key.
Return
| ||||||||||
virtual Object::Holder | put (Object::View vKey, Object::Holder ohValue) | |||||||||
Associate the specified value with the specified key in this map. If the map previously contained a mapping for this key, the old value is replaced by the specified value.
| ||||||||||
virtual Object::Holder | remove (Object::View vKey) | |||||||||
Remove the mapping for this key from this map if it is present.
Return the value to which the map previously associated the key, or
| ||||||||||
virtual void | putAll (Map::View vMap) | |||||||||
Copy all of the mappings from the specified map to this map.
The effect of this call is equivalent to that of calling put(k, v) on this map once for each mapping from key
| ||||||||||
virtual void | clear () | |||||||||
Remove all mappings from this map.
| ||||||||||
virtual Set::View | keySet () const | |||||||||
Return a set of the keys contained in this map. The set is backed by the map, so changes to the map are reflected in the set. If the map is modified while an iteration over the set is in progress, the results of the iteration are undefined.
| ||||||||||
virtual Set::Handle | keySet () | |||||||||
Return a set of the keys contained in this map. The set is backed by the map, so changes to one are reflected in the other. If the map is modified while an iteration over the set is in progress, the results of the iteration are undefined.
| ||||||||||
virtual Collection::View | values () const | |||||||||
Return a collection of the values contained in this map. The collection is backed by the map, so changes to the map are reflected in the set. If the map is modified while an iteration over the collection is in progress, the results of the iteration are undefined.
| ||||||||||
virtual Collection::Handle | values () | |||||||||
Return a collection of the values contained in this map. The collection is backed by the map, so changes to one are reflected in the other. If the map is modified while an iteration over the collection is in progress, the results of the iteration are undefined.
| ||||||||||
virtual Set::View | entrySet () const | |||||||||
Return a set of the mappings contained in this map. Each element in the returned set is a Map::Entry::View. The set is backed by the map, so changes to the map are reflected in the set. If the map is modified while an iteration over the set is in progress, the results of the iteration are undefined.
| ||||||||||
virtual Set::Handle | entrySet () | |||||||||
Return a set of the mappings contained in this map. Each element in the returned set is a Map::Entry::Handle. The set is backed by the map, so changes to one are reflected in the other. If the map is modified while an iteration over the set is in progress, the results of the iteration are undefined.
| ||||||||||
virtual TypedHandle < const String > | toString () const | |||||||||
Output a human-readable description of this Object to the given stream. Note that when overriding this method the return type must be TypedHandle<const String> rather then String::View. These two types are assignment compatible but not equivalent and declaring the override with String::View will not be a compatible override. coherence::lang::operator<<(std::ostream, Object::View) is defined and will call into the toString method, to output Objects. If a managed String object is desired, the COH_TO_STRING macro can be used to build up a String from streamable contents and is generally how toString() will be implemented.
Object::View vKey = ... Object::View vValue = ... std::cout << vKey << " = " << vValue << std::endl; String::View vs = COH_TO_STRING(vKey << " = " << vValue); The COH_TO_STRING macro is also the most common way to implement the toString method. For example:
virtual TypedHandle<const String> Person::toString() const { return COH_TO_STRING("Name: " << f_sName << " SSN: " << f_nSSN); }
| ||||||||||
virtual size32_t | hashCode () const | |||||||||
Return a hash code value for the Object. This method is supported for the benefit of hash-based containers.
The general contract of
The default implementation is identity based.
| ||||||||||
virtual bool | equals (Object::View v) const | |||||||||
virtual bool | isImmutable () const | |||||||||
Return true iff no further changes can be made to the Object, that would effect the outcome of a call to its equals method.Except for Objects which are naturally immutable (such as String), being immutable generally implies that the Object is only referenced via const pointers or views. Objects which hold references to child Objects, may need to take the immutability of their children into account when determining their own immutability. This extended check is not performed by the default implementation, but can be integrated into the immutability checks by overriding this method, as well as making use of MemberHandles to reference child Objects. A typical derived implementation may look as follows:
bool isImmutable() const { if (m_fImmutable) // check recorded state { return true; // already marked as immutable, avoid calculation } else if (Object::isImmutable()) // ensure shallow immutability { // ensure deep immutability if (m_child1->isImmutable() && m_child2->isImmutable() ... && m_childN->isImmutable()) { // record and return immutability return m_fImmutable = true; } // some Objects which comprise this Object are still mutable } return false; } The default implementation return true iff the Object is only referenced via const pointers and or views.
| ||||||||||
Protected Member Functions | ||||||||||
AbstractWrapperMap (Map::Holder ohMapDelegate) | ||||||||||
Create an AbstractWrapperMap which delegates to the specified Map. | ||||||||||
AbstractWrapperMap (const AbstractWrapperMap &that) | ||||||||||
Copy constructor. | ||||||||||
virtual Map::Handle | getDelegate () | |||||||||
Return a handle to the delegate. | ||||||||||
virtual Map::View | getDelegate () const | |||||||||
Return a view to the delegate. |
AbstractWrapperMap | ( | Map::Holder | ohMapDelegate | ) | [protected] |
Create an AbstractWrapperMap which delegates to the specified Map.
ohMapDelegate | the Map to delegate to |
virtual Map::Handle getDelegate | ( | ) | [protected, virtual] |
Return a handle to the delegate.
UnsupportedOperationException | if the delegate is a view |
virtual Map::View getDelegate | ( | ) | const [protected, virtual] |
Return a view to the delegate.