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

F79659-03

coherence/util/Binary.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_BINARY_HPP
00008 #define COH_BINARY_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/AbstractOctetArrayReadBuffer.hpp"
00013 #include "coherence/io/ReadBuffer.hpp"
00014 #include "coherence/util/BinaryWriteBuffer.hpp"
00015 
00016 COH_OPEN_NAMESPACE2(coherence,util)
00017 
00018 using coherence::io::AbstractOctetArrayReadBuffer;
00019 using coherence::io::ReadBuffer;
00020 
00021 
00022 /**
00023 * A thread-safe immutable binary object.
00024 *
00025 * @author jh  2008.05.29
00026 */
00027 class COH_EXPORT Binary
00028     : public cloneable_spec<Binary,
00029         extends<AbstractOctetArrayReadBuffer> >
00030     {
00031     friend class factory<Binary>;
00032 
00033     // ----- constructors ---------------------------------------------------
00034 
00035     private:
00036         /**
00037         * Default constructor for a Binary object. Supports deserialization.
00038         *
00039         * @since Coherence 3.7.1
00040         */
00041         Binary();
00042 
00043         /**
00044         * Construct a Binary object from a portion of an octet Array.
00045         *
00046         * @param vab  an Array of octets; must not be NULL
00047         * @param of   the offset into the octet Array
00048         * @param cb   the number of octets to extract or npos for
00049         *             (vab->length - of)
00050         *
00051         * @throws  IndexOutOfBoundsException if <code>of + cb</code> is
00052         *          larger than <code>vab->length</code>
00053         * @throws  NullPointerException if <code>vab</code> is
00054         *          <code>NULL</code>
00055         */
00056         Binary(Array<octet_t>::View vab, size32_t of = 0, size32_t cb = npos);
00057 
00058         /**
00059         * Construct a Binary object from a BinaryWriteBuffer.
00060         *
00061         * @param vBuf  a BinaryWriteBuffer to construct this Binary object from
00062         *
00063         * @since Coherence 3.7.1
00064         */
00065         Binary(BinaryWriteBuffer::View vBuf);
00066 
00067         /**
00068         * Copy constructor.
00069         */
00070         Binary(const Binary& that);
00071 
00072 
00073     // ----- Binary interface -----------------------------------------------
00074 
00075     public:
00076         /**
00077         * Calculate the partition ID to which the specified Binary should be
00078         * naturally assigned. This calculation should not be applied to
00079         * Binary objects decorated with artificially assigned partitions.
00080         *
00081         * The resulting partition ID will be in the range [0..cPartitions).
00082         *
00083         * @param cPartitions  the partition count
00084         *
00085         * @return the partition that the this Binary is naturally assigned to
00086         *
00087         * @since Coherence 3.7.1
00088         */
00089         virtual int32_t calculateNaturalPartition(int32_t cPartitions) const;
00090 
00091 
00092     // ----- Object interface -----------------------------------------------
00093 
00094     public:
00095         /**
00096         * {@inheritDoc}
00097         */
00098         virtual size32_t hashCode() const;
00099 
00100         /**
00101         * {@inheritDoc}
00102         */
00103         virtual bool equals(Object::View v) const;
00104 
00105         /**
00106         * {@inheritDoc}
00107         */
00108         virtual bool isImmutable() const;
00109 
00110         /**
00111         * {@inheritDoc}
00112         */
00113         virtual TypedHandle<const String> toString() const;
00114 
00115 
00116     // ----- internal methods -----------------------------------------------
00117 
00118     protected:
00119         /**
00120         * {@inheritDoc}
00121         */
00122         virtual void updateLength(size32_t cb);
00123 
00124         /**
00125         * {@inheritDoc}
00126         */
00127         virtual ReadBuffer::View instantiateReadBuffer(size32_t of,
00128                 size32_t cb) const;
00129     };
00130 
00131 COH_CLOSE_NAMESPACE2
00132 
00133 #endif // COH_BINARY_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.