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

com.swirlds.common.merkle.MerkleInternal Maven / Gradle / Ivy

Go to download

Swirlds is a software platform designed to build fully-distributed applications that harness the power of the cloud without servers. Now you can develop applications with fairness in decision making, speed, trust and reliability, at a fraction of the cost of traditional server-based platforms.

There is a newer version: 0.56.6
Show newest version
/*
 * Copyright (C) 2016-2024 Hedera Hashgraph, LLC
 *
 * 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 com.swirlds.common.merkle;

import com.swirlds.common.merkle.impl.PartialBinaryMerkleInternal;
import com.swirlds.common.merkle.impl.PartialNaryMerkleInternal;
import com.swirlds.common.merkle.interfaces.MerkleParent;
import com.swirlds.common.merkle.interfaces.Rebuildable;

/**
 * 

A MerkleInternal is one interior node in a Merkle tree structure. * It has the following properties: *

    *
  • It only has children (no data)
  • *
  • Each child is a MerkleNode object
  • *
  • Requires a no-arg constructor (due to inheritance from RuntimeConstructable)
  • *
  • Requires a constructor that takes {@code List children}
  • *
* * * A MerkleInternal node may have utility methods that increase the number of children after the node has been * constructed. Child nodes MUST NOT be generated or modified in the following functions: * * - The zero-argument constructor * - getNumberOfChildren() * - getChild() * - isLeaf() * * It is highly recommended that any class implementing this interface extend either * {@link PartialBinaryMerkleInternal} (if the node has 2 or fewer children) or {@link PartialNaryMerkleInternal} * (if the node has greater than 2 children). */ public interface MerkleInternal extends MerkleNode, MerkleParent, Rebuildable { /** * {@inheritDoc} * * There are currently 3 strategies that internal nodes use to perform copy. * * 1) Cascading copy. When a node using this strategy is copied it simply calls copy on all of its children and * adds those copies to the new object. This is inefficient -- a copy of a tree that uses cascading copy is an * O(n) operation (where n is the number of nodes). * * 2) Smart copy (aka copy-on-write). When a node using this strategy is copied, it copies the root * of its subtree. When a descendant is modified, it creates a path from the root down to the node * and then modifies the copy of the node. * * 3) Self copy. When this internal node is copied it only copies metadata. Its children are uncopied, and the new * node has null in place of any children. This strategy can only CURRENTLY be used on nodes where copying is * managed by an ancestor node (for example, an ancestor that does smart copies). * * Eventually there will be utilities that manage all aspects of copying a merkle tree. At that point in time, all * internal nodes will be required to implement copy strategy 3. */ @Override MerkleInternal copy(); /** * {@inheritDoc} */ @Override default void rebuild() {} }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy