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

net.openhft.chronicle.hash.ChecksumEntry Maven / Gradle / Ivy

/*
 * Copyright 2012-2018 Chronicle Map Contributors
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package net.openhft.chronicle.hash;

import net.openhft.chronicle.map.MapAbsentEntry;
import net.openhft.chronicle.map.MapEntry;
import net.openhft.chronicle.set.SetEntry;

/**
 * Abstracts entries of hash containers, created by {@link ChronicleHashBuilder}s
 * with {@link ChronicleHashBuilder#checksumEntries(boolean)} configured to {@code true}. There is
 * no method that returns {@code ChecksumEntry}, {@link MapEntry} or {@link SetEntry} could be
 * casted to {@code ChecksumEntry} to access it's methods.
 * 

*

See Entry checksums * section in the Chronicle Map tutorial for usage examples of this interface. */ public interface ChecksumEntry { /** * Re-computes and stores checksum for the entry. This method shouldn't be called before * or after ordinary operations like {@link MapAbsentEntry#doInsert(Data)}, {@link * MapEntry#doReplaceValue(Data)}: it is performed automatically underneath. Call this method, * only when value bytes was updated directly, for example though flyweight implementation of * a value * interface. * * @throws UnsupportedOperationException if checksums are not stored in the containing Chronicle * Hash * @throws RuntimeException if the context of this entry is locked improperly, e. g. on the * {@linkplain HashQueryContext#readLock() read} level, that is not upgradable to the * {@linkplain HashQueryContext#updateLock() update} level. Calling {@code updateChecksum()} * method is enabled when at least update lock is held. */ void updateChecksum(); /** * Computes checksum from the entry bytes and checks whether it is equal to the stored checksum. * * @return {@code true} if stored checksum equals to checksum computed from the entry bytes * @throws UnsupportedOperationException if checksums are not stored in the containing Chronicle * Hash * @throws RuntimeException if the context of this entry is locked improperly, e. g. on the * {@linkplain HashQueryContext#readLock() read} level, that is not upgradable to the * {@linkplain HashQueryContext#updateLock() update} level. Calling {@code checkSum()} method is * enabled when at least update lock is held. */ boolean checkSum(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy