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

io.github.icodegarden.commons.lang.algorithm.consistenthash.VirtualNode Maven / Gradle / Ivy

package io.github.icodegarden.commons.lang.algorithm.consistenthash;

import java.util.Objects;

/**
 * 虚拟节点
 * 
 * @author Fangfang.Xu
 */
public class VirtualNode implements Node {

	private final T physicalNode;
	private final int number;

	public VirtualNode(T physicalNode, int number) {
		this.number = number;
		this.physicalNode = physicalNode;
	}

	/**
	 * 虚拟节点的key=物理节点key-虚拟节点number
	 */
	@Override
	public String getKey() {
		return physicalNode.getKey() + "-" + number;
	}

	/**
	 * 是否指定物理节点的虚拟节点
	 */
	public boolean isVirtualNodeOf(T pNode) {
		return physicalNode.getKey().equals(pNode.getKey());
	}

	public T getPhysicalNode() {
		return physicalNode;
	}

	@Override
	public int hashCode() {
		return Objects.hash(number, physicalNode);
	}

	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		VirtualNode other = (VirtualNode) obj;
		return number == other.number && Objects.equals(physicalNode, other.physicalNode);
	}

	@Override
	public String toString() {
		return "VirtualNode [number=" + number + "]";
	}
	
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy