Interface ByteCollection
- All Superinterfaces:
it.unimi.dsi.fastutil.bytes.ByteIterable,java.util.Collection<java.lang.Byte>,java.lang.Iterable<java.lang.Byte>
- All Known Subinterfaces:
ByteBigList,ByteList,ByteSet,ByteSortedSet
- All Known Implementing Classes:
AbstractByteBigList,AbstractByteBigList.ByteRandomAccessSubList,AbstractByteBigList.ByteSubList,AbstractByteCollection,AbstractByteList,AbstractByteList.ByteRandomAccessSubList,AbstractByteList.ByteSubList,AbstractByteSet,AbstractByteSortedSet,ByteArrayList,ByteArraySet,ByteAVLTreeSet,ByteBigArrayBigList,ByteBigLists.EmptyBigList,ByteBigLists.ListBigList,ByteBigLists.Singleton,ByteBigLists.SynchronizedBigList,ByteBigLists.UnmodifiableBigList,ByteCollections.EmptyCollection,ByteCollections.IterableCollection,ByteImmutableList,ByteLinkedOpenCustomHashSet,ByteLinkedOpenHashSet,ByteLists.EmptyList,ByteLists.Singleton,ByteLists.SynchronizedList,ByteLists.SynchronizedRandomAccessList,ByteLists.UnmodifiableList,ByteLists.UnmodifiableRandomAccessList,ByteOpenCustomHashSet,ByteOpenHashSet,ByteRBTreeSet,ByteSets.EmptySet,ByteSets.Singleton,ByteSets.SynchronizedSet,ByteSets.UnmodifiableSet,ByteSortedSets.EmptySet,ByteSortedSets.Singleton,ByteSortedSets.SynchronizedSortedSet,ByteSortedSets.UnmodifiableSortedSet
public interface ByteCollection
extends java.util.Collection<java.lang.Byte>, it.unimi.dsi.fastutil.bytes.ByteIterable
Collection; provides some additional methods
that use polymorphism to avoid (un)boxing.
Additionally, this class defines strengthens (again) iterator().
This interface specifies reference equality semantics (members will be compared equal with
== instead of equals), which may result in breaks in contract
if attempted to be used with non reference-equality semantics based Collections. For example, a
aReferenceCollection.equals(aObjectCollection) may return different a different result then
aObjectCollection.equals(aReferenceCollection), in violation of equals's
contract requiring it being symmetric.
- See Also:
Collection
-
Method Summary
Modifier and Type Method Description booleanadd(byte key)Ensures that this collection contains the specified element (optional operation).default booleanadd(java.lang.Byte key)Deprecated.Please use the corresponding type-specific method instead.booleanaddAll(ByteCollection c)Adds all elements of the given type-specific collection to this collection.booleancontains(byte key)Returnstrueif this collection contains the specified element.default booleancontains(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.booleancontainsAll(ByteCollection c)Checks whether this collection contains all elements from the given type-specific collection.default it.unimi.dsi.fastutil.ints.IntIteratorintIterator()Returns a widened primitive iterator on the elements of this collection.default java.util.stream.IntStreamintParallelStream()Return a parallel primitive stream over the elements, performing widening casts if needed.default it.unimi.dsi.fastutil.ints.IntSpliteratorintSpliterator()Returns widened primitive spliterator on the elements of this collection.default java.util.stream.IntStreamintStream()Return a primitive stream over the elements, performing widening casts if needed.it.unimi.dsi.fastutil.bytes.ByteIteratoriterator()Returns a type-specific iterator on the elements of this collection.default java.util.stream.Stream<java.lang.Byte>parallelStream()Deprecated.Please use the corresponding type-specific method instead.booleanrem(byte key)Removes a single instance of the specified element from this collection, if it is present (optional operation).default booleanremove(java.lang.Object key)Deprecated.Please use (and implement) therem()method instead.booleanremoveAll(ByteCollection c)Remove from this collection all elements in the given type-specific collection.default booleanremoveIf(BytePredicate filter)Remove from this collection all elements which satisfy the given predicate.default booleanremoveIf(java.util.function.IntPredicate filter)Remove from this collection all elements which satisfy the given predicate.default booleanremoveIf(java.util.function.Predicate<? super java.lang.Byte> filter)Deprecated.Please use the corresponding type-specific method instead.booleanretainAll(ByteCollection c)Retains in this collection only elements from the given type-specific collection.default it.unimi.dsi.fastutil.bytes.ByteSpliteratorspliterator()Returns a type-specific spliterator on the elements of this collection.default java.util.stream.Stream<java.lang.Byte>stream()Deprecated.Please use the corresponding type-specific method instead.byte[]toArray(byte[] a)Returns an array containing all of the elements in this collection; the runtime type of the returned array is that of the specified array.byte[]toByteArray()Returns a primitive type array containing the items of this collection.default byte[]toByteArray(byte[] a)Deprecated.Please usetoArray()instead—this method is redundant and will be removed in the future.Methods inherited from interface it.unimi.dsi.fastutil.bytes.ByteIterable
forEach, forEach, forEachMethods inherited from interface java.util.Collection
addAll, clear, containsAll, equals, hashCode, isEmpty, removeAll, retainAll, size, toArray, toArray, toArray
-
Method Details
-
iterator
it.unimi.dsi.fastutil.bytes.ByteIterator iterator()Returns a type-specific iterator on the elements of this collection.- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.bytes.ByteIterable- Specified by:
iteratorin interfacejava.util.Collection<java.lang.Byte>- Specified by:
iteratorin interfacejava.lang.Iterable<java.lang.Byte>- Returns:
- a type-specific iterator on the elements of this collection.
- API Notes:
- This specification strengthens the one given in
Iterable.iterator(), which was already strengthened in the corresponding type-specific class, but was weakened by the fact that this interface extendsCollection.
-
intIterator
default it.unimi.dsi.fastutil.ints.IntIterator intIterator()Returns a widened primitive iterator on the elements of this collection.This method is provided for the purpose of APIs that expect only the JDK's primitive iterators, of which there are only
int,long, anddouble.- Specified by:
intIteratorin interfaceit.unimi.dsi.fastutil.bytes.ByteIterable- Returns:
- a widened primitive iterator on the elements of this collection.
- Since:
- 8.5.0
-
spliterator
default it.unimi.dsi.fastutil.bytes.ByteSpliterator spliterator()Returns a type-specific spliterator on the elements of this collection.See
Collection.spliterator()for more documentation on the requirements of the returned spliterator.- Specified by:
spliteratorin interfaceit.unimi.dsi.fastutil.bytes.ByteIterable- Specified by:
spliteratorin interfacejava.util.Collection<java.lang.Byte>- Specified by:
spliteratorin interfacejava.lang.Iterable<java.lang.Byte>- Returns:
- a type-specific spliterator on the elements of this collection.
- Since:
- 8.5.0
- API Notes:
- This specification strengthens the one given in
Collection.spliterator().Also, this is generally the only
spliteratormethod subclasses should override. - Implementation Specification:
- The default implementation returns a late-binding spliterator (see
Spliteratorfor documentation on what binding policies mean) that wraps this instance's type specificiterator().Additionally, it reports
Spliterator.SIZED - Implementation Notes:
- As this default implementation wraps the iterator, and
Iteratoris an inherently linear API, the returned spliterator will yield limited performance gains when run in parallel contexts, as the returned spliterator'strySplit()will have linear runtime.
-
intSpliterator
default it.unimi.dsi.fastutil.ints.IntSpliterator intSpliterator()Returns widened primitive spliterator on the elements of this collection.This method is provided for the purpose of APIs that expect only the JDK's primitive spliterators, of which there are only
int,long, anddouble.- Specified by:
intSpliteratorin interfaceit.unimi.dsi.fastutil.bytes.ByteIterable- Returns:
- a widened primitive spliterator on the elements of this collection.
- Since:
- 8.5.0
-
add
boolean add(byte key)Ensures that this collection contains the specified element (optional operation).- See Also:
Collection.add(Object)
-
contains
boolean contains(byte key)Returnstrueif this collection contains the specified element.- See Also:
Collection.contains(Object)
-
rem
boolean rem(byte key)Removes a single instance of the specified element from this collection, if it is present (optional operation).Note that this method should be called
remove(), but the clash with the similarly named index-based method in theListinterface forces us to use a distinguished name. For simplicity, the set interfaces reinstatesremove().- See Also:
Collection.remove(Object)
-
add
@Deprecated default boolean add(java.lang.Byte key)Deprecated.Please use the corresponding type-specific method instead.- Specified by:
addin interfacejava.util.Collection<java.lang.Byte>
-
contains
@Deprecated default boolean contains(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.- Specified by:
containsin interfacejava.util.Collection<java.lang.Byte>
-
remove
@Deprecated default boolean remove(java.lang.Object key)Deprecated.Please use (and implement) therem()method instead.- Specified by:
removein interfacejava.util.Collection<java.lang.Byte>
-
toByteArray
byte[] toByteArray()Returns a primitive type array containing the items of this collection.- Returns:
- a primitive type array containing the items of this collection.
- See Also:
Collection.toArray()
-
toByteArray
@Deprecated default byte[] toByteArray(byte[] a)Deprecated.Please usetoArray()instead—this method is redundant and will be removed in the future.Returns a primitive type array containing the items of this collection.Note that, contrarily to
Collection.toArray(Object[]), this methods just writes all elements of this collection: no special value will be added after the last one.- Parameters:
a- if this array is big enough, it will be used to store this collection.- Returns:
- a primitive type array containing the items of this collection.
- See Also:
Collection.toArray(Object[])
-
toArray
byte[] toArray(byte[] a)Returns an array containing all of the elements in this collection; the runtime type of the returned array is that of the specified array.Note that, contrarily to
Collection.toArray(Object[]), this methods just writes all elements of this collection: no special value will be added after the last one.- Parameters:
a- if this array is big enough, it will be used to store this collection.- Returns:
- a primitive type array containing the items of this collection.
- See Also:
Collection.toArray(Object[])
-
addAll
Adds all elements of the given type-specific collection to this collection.- Parameters:
c- a type-specific collection.- Returns:
trueif this collection changed as a result of the call.- See Also:
Collection.addAll(Collection)
-
containsAll
Checks whether this collection contains all elements from the given type-specific collection.- Parameters:
c- a type-specific collection.- Returns:
trueif this collection contains all elements of the argument.- See Also:
Collection.containsAll(Collection)
-
removeAll
Remove from this collection all elements in the given type-specific collection.- Parameters:
c- a type-specific collection.- Returns:
trueif this collection changed as a result of the call.- See Also:
Collection.removeAll(Collection)
-
removeIf
@Deprecated default boolean removeIf(java.util.function.Predicate<? super java.lang.Byte> filter)Deprecated.Please use the corresponding type-specific method instead.- Specified by:
removeIfin interfacejava.util.Collection<java.lang.Byte>
-
removeIf
Remove from this collection all elements which satisfy the given predicate.- Parameters:
filter- a predicate which returnstruefor elements to be removed.- Returns:
trueif any elements were removed.- See Also:
Collection.removeIf(java.util.function.Predicate)- API Notes:
- Implementing classes should generally override this method, and take the default implementation of the other overloads which will delegate to this method (after proper conversions).
-
removeIf
default boolean removeIf(java.util.function.IntPredicate filter)Remove from this collection all elements which satisfy the given predicate.- Parameters:
filter- a predicate which returnstruefor elements to be removed.- Returns:
trueif any elements were removed.- See Also:
Collection.removeIf(java.util.function.Predicate)- Implementation Notes:
- Unless the argument is type-specific, this method will introduce an intermediary lambda to perform widening casts. Please use the type-specific overload to avoid this overhead.
-
retainAll
Retains in this collection only elements from the given type-specific collection.- Parameters:
c- a type-specific collection.- Returns:
trueif this collection changed as a result of the call.- See Also:
Collection.retainAll(Collection)
-
stream
@Deprecated default java.util.stream.Stream<java.lang.Byte> stream()Deprecated.Please use the corresponding type-specific method instead.- Specified by:
streamin interfacejava.util.Collection<java.lang.Byte>
-
intStream
default java.util.stream.IntStream intStream()Return a primitive stream over the elements, performing widening casts if needed.- Returns:
- a primitive stream over the elements.
- See Also:
Collection.stream(),IntStream
-
parallelStream
@Deprecated default java.util.stream.Stream<java.lang.Byte> parallelStream()Deprecated.Please use the corresponding type-specific method instead.- Specified by:
parallelStreamin interfacejava.util.Collection<java.lang.Byte>
-
intParallelStream
default java.util.stream.IntStream intParallelStream()Return a parallel primitive stream over the elements, performing widening casts if needed.- Returns:
- a parallel primitive stream over the elements.
- See Also:
Collection.parallelStream(),IntStream
-