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

org.infinispan.functional.EntryView Maven / Gradle / Ivy

package org.infinispan.functional;

import java.util.NoSuchElementException;
import java.util.Optional;
import java.util.function.Consumer;
import java.util.function.Function;

import org.infinispan.commons.util.Experimental;
import org.infinispan.metadata.Metadata;

/**
 * Entry views expose cached entry information to the user. Depending on the
 * type of entry view, different operations are available. Currently, three
 * type of entry views are supported:
 *
 * 
    * {@link ReadEntryView}: read-only entry view * {@link WriteEntryView}: write-only entry view * {@link ReadWriteEntryView}: read-write entry view *
* * @since 8.0 */ @Experimental public final class EntryView { private EntryView() { // Cannot be instantiated, it's just a holder class } /** * Expose read-only information about a cache entry potentially associated * with a key in the functional map. Typically, if the key is associated * with a cache entry, that information will include value and optional * {@link MetaParam} information. * *

It exposes both {@link #get()} and {@link #find()} methods for * convenience. If the caller knows for sure that the value will be * present, {@link #get()} offers the convenience of retrieving the value * directly without having to get an {@link Optional} first. As a result * of this, {@link #get()} throws {@link NoSuchElementException} if * there's no value associated with the entry. If the caller is unsure * of whether the value is present, {@link #find()} should be used. * This approach avoids the user having to do null checks. * * @since 8.0 */ @Experimental public interface ReadEntryView extends MetaParam.Lookup { /** * Key of the read-only entry view. Guaranteed to return a non-null value. * The instance of the key must not be mutated. */ K key(); /** * Returns a non-null value if the key has a value associated with it or * throws {@link NoSuchElementException} if no value is associated with * the entry. * *

The value instance is read-only and must not be mutated. If the function * accessing this value is about to update the entry, it has to create * a defensive copy (or completely new instance) and store it using * {@link WriteEntryView#set(Object, MetaParam.Writable[])}. * * @throws NoSuchElementException if no value is associated with the key. */ V get() throws NoSuchElementException; /** * Optional value. It'll return a non-empty value when the value is present, * and empty when the value is not present. * *

The value instance is read-only and must not be mutated. If the function * accessing this value is about to update the entry, it has to create * a defensive copy (or completely new instance) and store it using * {@link WriteEntryView#set(Object, MetaParam.Writable[])}. */ Optional find(); /** * The same as {@link #find()} but does not update any hit/miss statistics. * @return */ default Optional peek() { return find(); } } /** * Expose a write-only facade for a cache entry potentially associated with a key * in the functional map which allows the cache entry to be written with * new value and/or new metadata parameters. * * @since 8.0 */ @Experimental public interface WriteEntryView { /** * Key of the write-only entry view. Guaranteed to return a non-null value. * The instance of the key must not be mutated. */ K key(); /** * Set this value along with optional metadata parameters. * *

This method returns {@link Void} instead of 'void' to avoid * having to add overloaded methods in functional map that take * {@link Consumer} instead of {@link Function}. This is an * unfortunate side effect of the Java language itself which does * not consider 'void' to be an {@link Object}. */ Void set(V value, MetaParam.Writable... metas); /** * Set this value along with metadata object. * *

This method returns {@link Void} instead of 'void' to avoid * having to add overloaded methods in functional map that take * {@link Consumer} instead of {@link Function}. This is an * unfortunate side effect of the Java language itself which does * not consider 'void' to be an {@link Object}. */ Void set(V value, Metadata metadata); /** * Removes the value and any metadata parameters associated with it. * *

This method returns {@link Void} instead of 'void' to avoid * having to add overloaded methods in functional map that take * {@link Consumer} instead of {@link Function}. This is an * unfortunate side effect of the Java language itself which does * not consider 'void' to be an {@link Object}. */ Void remove(); } /** * Expose information about a cache entry potentially associated with a key * in the functional map, and allows that cache entry to be written with * new value and/or new metadata parameters. * * @since 8.0 */ @Experimental public interface ReadWriteEntryView extends ReadEntryView, WriteEntryView {} }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy