C++ Client API Reference for Oracle Coherence
14c (14.1.2.0.0)

F79659-03

coherence/util/CompositeKey.hpp

00001 /*
00002  * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
00003  *
00004  * Licensed under the Universal Permissive License v 1.0 as shown at
00005  * http://oss.oracle.com/licenses/upl.
00006  */
00007 #ifndef COH_COMPOSITE_KEY_HPP
00008 #define COH_COMPOSITE_KEY_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/pof/PofReader.hpp"
00013 #include "coherence/io/pof/PofWriter.hpp"
00014 #include "coherence/io/pof/PortableObject.hpp"
00015 #include "coherence/net/cache/KeyAssociation.hpp"
00016 
00017 
00018 
00019 COH_OPEN_NAMESPACE2(coherence,util)
00020 
00021 using coherence::io::pof::PofReader;
00022 using coherence::io::pof::PofWriter;
00023 using coherence::io::pof::PortableObject;
00024 using coherence::net::cache::KeyAssociation;
00025 
00026 
00027 /**
00028 * Key class that consists of a primary and secondary component. Two instances
00029 * of CompositeKey are considered to be equal iff both the primary and
00030 * secondary components of the two instances are considered equal.
00031 * Additionally, the hash code of a CompositeKey takes into the consideration
00032 * the hash codes of its two components. Finally, the CompositeKey class
00033 * implements KeyAssociation by returning the primary component.
00034 *
00035 * @author wl 2010.09.02
00036 */
00037 class COH_EXPORT CompositeKey
00038     : public class_spec<CompositeKey,
00039         extends<Object>,
00040         implements<KeyAssociation, PortableObject> >
00041     {
00042     friend class factory<CompositeKey>;
00043 
00044     // ----- constructors ---------------------------------------------------
00045 
00046     protected:
00047         /**
00048         * Default constructor.
00049         */
00050         CompositeKey();
00051 
00052         /**
00053         * Create a new CompositeKey that consists of the given primary and
00054         * secondary components.
00055         *
00056         * @param voPrimary   the primary key component; must not be null. This
00057         *                    is also the host key returned by the 
00058         *                    KeyAssociation implementation
00059         * @param voSecondary the secondary key component; must not be null
00060         */
00061         CompositeKey(Object::View voPrimary, Object::View voSecondary);
00062 
00063 
00064     // ----- KeyAssociation interface ---------------------------------------
00065 
00066     public:
00067         /**
00068         * {@inheritDoc}
00069         */
00070         virtual Object::View getAssociatedKey() const;
00071 
00072 
00073     // ----- PortableObject interface ---------------------------------------
00074 
00075     public:
00076         /**
00077         * {@inheritDoc}
00078         */
00079         virtual void readExternal(PofReader::Handle hIn);
00080 
00081         /**
00082         * {@inheritDoc}
00083         */
00084         virtual void writeExternal(PofWriter::Handle hOut) const;
00085 
00086 
00087     // ----- Object methods -------------------------------------------------
00088 
00089     public:
00090         /**
00091         * {@inheritDoc}
00092         */
00093         virtual size32_t hashCode() const;
00094 
00095         /**
00096         * {@inheritDoc}
00097         */
00098         virtual bool equals(Object::View v) const;
00099 
00100         /**
00101         * {@inheritDoc}
00102         */
00103         virtual TypedHandle<const String> toString() const;
00104 
00105 
00106     // ----- accessors ------------------------------------------------------
00107 
00108     public:
00109         /**
00110         * Return the primary key component.
00111         *
00112         * @return the primary key component
00113         */
00114         virtual Object::View getPrimaryKey() const;
00115 
00116         /**
00117         * Return the secondary key component.
00118         *
00119         * @return the secondary key component
00120         */
00121         virtual Object::View getSecondaryKey() const;
00122 
00123 
00124     // ----- data members ---------------------------------------------------
00125 
00126     private:
00127         /**
00128         * The primary key component.
00129         */
00130         FinalView<Object> f_voPrimary;
00131 
00132         /**
00133         * The secondary key component.
00134         */
00135         FinalView<Object> f_voSecondary;
00136     };
00137 
00138 COH_CLOSE_NAMESPACE2
00139 
00140 #endif // COH_COMPOSITE_KEY_HPP
Copyright © 2000, 2025, Oracle and/or its affiliates. Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl.