com.github.fmjsjx.libcommon.collection.LongSet Maven / Gradle / Ivy
package com.github.fmjsjx.libcommon.collection;
import java.util.Set;
import java.util.function.LongConsumer;
import java.util.stream.LongStream;
/**
* Interface for a primitive set that contains no duplicate {@code long}s.
*/
public interface LongSet extends Set {
/**
* Returns {@code true} if this set contains the specified value, {@code false}
* otherwise.
*
* @param value the value
* @return {@code true} if this set contains the specified value, {@code false}
* otherwise
*/
boolean contains(long value);
/**
* Adds the specified value to this set if it is not already present.
*
* @param value the value
* @return {@code true} if this set did not already contain the specified value,
* {@code false} otherwise
*/
boolean add(long value);
/**
* Removes the specified value from this set if it is present.
*
* @param value the value
* @return {@code true} if this set contained the specified value, {@code false}
* otherwise
*/
boolean remove(long value);
/**
* Returns a sequential {@link LongStream} with this set as its source.
*
* @return a sequential {@code LongStream} over the values in this set
*/
LongStream longStream();
/**
* Returns an array containing the values of this set.
*
* @return an array containing the values of this set
*/
default long[] tolongArray() {
return longStream().toArray();
}
/**
* Performs the given action for each value of this set.
*
* @param action The action to be performed for each value
*/
default void forEach(LongConsumer action) {
longStream().forEach(action);
}
/**
* Adds the specified values to this set if this set changed.
*
* @param values the values
* @return {@code true} if this set changed as a result of the call
*/
default boolean addAll(long... values) {
var modified = false;
for (var value : values) {
modified |= add(value);
}
return modified;
}
/**
* Removes from this set all of its value that are contained in the specified
* values.
*
* @param values the values
* @return {@code true} if this set changed as a result of the call
*/
default boolean containsAll(long... values) {
for (var e : values)
if (!contains(e))
return false;
return true;
}
/**
* Removes all of this set's values that are also contained in the specified
* set.
*
* @param values the values
* @return {@code true} if all of this set's values that are also contained in
* the specified array
*/
default boolean removeAll(long... values) {
boolean modified = false;
for (var value : values) {
modified |= remove(value);
}
return modified;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy