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

org.jgroups.AnycastAddress Maven / Gradle / Ivy

package org.jgroups;

import org.jgroups.util.Util;

import java.io.*;
import java.util.ArrayList;
import java.util.Collection;
import java.util.function.Supplier;

/**
 * This type of address represents a subset of the cluster members in which the total order properties must be applied,
 * e.g. if the cluster membership is {A,B,C,D,E}, an AnycastAddress could be {D,E}.
 *
 * @author Pedro Ruivo
 * @since 3.1
 */
public class AnycastAddress implements Address, Constructable {
    protected Collection
destinations; public AnycastAddress() { } public AnycastAddress(Collection
addresses) { addAll(addresses); } public AnycastAddress(Address... addresses) { add(addresses); } public Supplier create() { return AnycastAddress::new; } public void add(Address... addresses) { if (addresses.length == 0) { return; } initCollection(addresses.length); for (Address address : addresses) { internalAdd(address); } } protected void internalAdd(Address address) { if (!destinations.contains(address)) destinations.add(address); } public void addAll(Collection
addresses) { if (addresses == null || addresses.isEmpty()) { return; } initCollection(addresses.size()); addresses.forEach(this::internalAdd); } public Collection
getAddresses() { return destinations; } private void initCollection(int estimatedSize) { if (destinations == null) { destinations = new ArrayList<>(estimatedSize); } } public int serializedSize() { if (destinations == null) { return Global.INT_SIZE; } int size = Global.INT_SIZE; for (Address address : destinations) { size += Util.size(address); } return size; } @Override public String toString() { return "AnycastAddress " + destinations; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; AnycastAddress that = (AnycastAddress) o; return !(destinations != null ? !destinations.equals(that.destinations) : that.destinations != null); } @Override public int hashCode() { return destinations != null ? destinations.hashCode() : 0; } public int compareTo(Address o) { int hc1, hc2; if (this == o) return 0; if (!(o instanceof AnycastAddress)) throw new ClassCastException("comparison between different classes: the other object is " + (o != null ? o.getClass() : o)); AnycastAddress other = (AnycastAddress) o; hc1 = this.hashCode(); hc2 = other.hashCode(); if (hc1 == hc2) { int size = destinations == null ? 0 : destinations.size(); int otherSize = other.destinations == null ? 0 : other.destinations.size(); //it is always positive and they should be small. safe to do this: return size - otherSize; } else { return hc1 < hc2 ? -1 : 1; } } @Override public void writeTo(DataOutput out) throws Exception { Util.writeAddresses(destinations, out); } @Override public void readFrom(DataInput in) throws Exception { destinations = (Collection
) Util.readAddresses(in, ArrayList.class); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy