All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.tangosol.internal.util.collection.PortableConcurrentMap Maven / Gradle / Ivy

/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */
package com.tangosol.internal.util.collection;

import com.tangosol.io.ExternalizableLite;

import com.tangosol.io.pof.PofReader;
import com.tangosol.io.pof.PofWriter;
import com.tangosol.io.pof.PortableObject;

import com.tangosol.util.ExternalizableHelper;
import com.tangosol.util.WrapperCollections;

import com.tangosol.util.function.Remote;

import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;

import java.util.concurrent.ConcurrentHashMap;

import java.util.Map;

import javax.json.bind.annotation.JsonbProperty;

/**
 * A wrapper ConcurrentMap that controls wrapped map's serialization.
 *
 * @param  the key type
 * @param  the value type
 *
 * @author as  2014.11.19
 * @since 12.2.1
 */
@SuppressWarnings({"NullableProblems"})
public class PortableConcurrentMap
        extends WrapperCollections.ConcurrentWrapperMap
        implements PortableObject, ExternalizableLite
    {
    // ---- constructors ----------------------------------------------------

    /**
     * Default constructor.
     */
    public PortableConcurrentMap()
        {
        }

    /**
     * Construct RemoteConcurrentMap instance with a specified supplier.
     *
     * @param supplier  a wrapped set supplier
     */
    public PortableConcurrentMap(Remote.Supplier> supplier)
        {
        m_supplier = supplier;
        }

    /**
    * Return the supplier for this collection.
    *
    * @return the supplier.
    */
    public Remote.Supplier> getSupplier()
        {
        return m_supplier == null ? DEFAULT_SUPPLIER : m_supplier;
        }

    @Override
    protected Map getDelegate()
        {
        return m_mapDelegate == null ? (m_mapDelegate = getSupplier().get()) : m_mapDelegate;
        }

    // ---- ExternalizableLite implementation -------------------------------

    @Override
    public void readExternal(DataInput in) throws IOException
        {
        m_supplier = ExternalizableHelper.readObject(in);
        ExternalizableHelper.readMap(in, getDelegate(), null);
        }

    @Override
    public void writeExternal(DataOutput out) throws IOException
        {
        ExternalizableHelper.writeObject(out, m_supplier);
        ExternalizableHelper.writeMap(out, getDelegate());
        }

    // ---- PortableObject implementation -----------------------------------

    @Override
    public void readExternal(PofReader in) throws IOException
        {
        m_supplier    = in.readObject(0);
        m_mapDelegate = in.readMap(1, getDelegate());
        }

    @Override
    public void writeExternal(PofWriter out) throws IOException
        {
        out.writeObject(0, m_supplier);
        out.writeMap(1, getDelegate());
        }

    // ---- static members -------------------------------------------------

    /**
     * Default supplier for the wrapped ConcurrentMap instance, used for
     * interoperability with .NET and C++ clients which are not able to handle
     * lambda-based Java suppliers.
     */
    protected static final Remote.Supplier DEFAULT_SUPPLIER = ConcurrentHashMap::new;

    // ---- data members ----------------------------------------------------

    /**
     * Supplier for the wrapped ConcurrentMap instance.
     */
    @JsonbProperty("supplier")
    protected Remote.Supplier> m_supplier;
    }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy