Can

Immutable Iterable , that can specifically represent 3 possible variants of Cardinality .

Java’s Optional , can be seen as a holder of element(s), that is restricted to cardinality ZERO or ONE. Can is the logical extension to that, allowing also a cardinality of MULTIPLE.

Same idiomatic convention applies: References to Can should never be initialized to null .

*IMPORTANT:* A xref:refguide:commons:index/collections/Can.adoc[Can] must not contain _null_ elements. If you need to store _null_ , then use a different data structure, for example a regular _java.util.List java.util.List_ .

API

Can.java
interface Can<T> {
  Optional<T> get(int elementIndex)     (1)
  Optional<T> getRelativeToLast(int offset)     (2)
  T getElseFail(int elementIndex)     (3)
  T getRelativeToLastElseFail(int offset)     (4)
  int compareTo(Can<T> o)     (5)
  Optional<T> getFirst()     (6)
  T getFirstElseFail()     (7)
  Optional<T> getLast()     (8)
  T getLastElseFail()     (9)
  Can<T> empty()     (10)
  Can<T> ofNullable(T element)     (11)
  Can<T> ofSingleton(T element)     (12)
  Can<T> of(T... array)     (13)
  Can<T> ofArray(T[] array)     (14)
  Can<T> ofCollection(Collection<T> collection)     (15)
  Can<T> ofIterable(Iterable<T> iterable)     (16)
  Can<T> ofEnumeration(Enumeration<T> enumeration)     (17)
  Can<T> ofStream(Stream<T> stream)     (18)
  Can<T> sorted(Comparator<? super T> comparator)     (19)
  Can<T> distinct()     (20)
  Can<T> distinct(BiPredicate<T, T> equality)     (21)
  Can<T> reverse()     (22)
  Can<T> filter(Predicate<? super T> predicate)     (23)
  Can<R> map(Function<? super T, R> mapper)     (24)
  Can<R> flatMap(Function<? super T, ? extends Can<? extends R>> mapper)
  Can<T> reduce(BinaryOperator<T> accumulator)     (25)
  Can<T> concat(Can<T> can, T element)     (26)
  Iterator<T> iterator(int skip, int limit)     (27)
  Iterator<T> reverseIterator()
  void forEach(Consumer<? super T> action)
  void zip(Iterable<R> zippedIn, BiConsumer<? super T, ? super R> action)     (28)
  Can<R> zipMap(Iterable<Z> zippedIn, BiFunction<? super T, ? super Z, R> mapper)     (29)
  Stream<R> zipStream(Iterable<Z> zippedIn, BiFunction<? super T, ? super Z, R> mapper)     (30)
  Can<T> add(T element)
  Can<T> addUnique(T element)     (31)
  Can<T> addAll(Can<T> other)
  Can<T> add(int index, T element)     (32)
  Can<T> replace(int index, T element)
  Can<T> remove(int index)     (33)
  Can<T> remove(T element)
  Can<T> pickByIndex(int... indices)     (34)
  Can<T> pickByIndex(IntStream intStream)     (35)
  Can<T> subCan(int startInclusive)     (36)
  Can<T> subCan(int startInclusive, int endExclusive)     (37)
  Can<Can<T>> partitionInnerBound(int maxInnerSize)     (38)
  Can<Can<T>> partitionOuterBound(int outerSizeYield)     (39)
  int indexOf(T element)     (40)
  boolean anyMatch(Predicate<? super T> predicate)     (41)
  boolean allMatch(Predicate<? super T> predicate)     (42)
  boolean isEqualTo(Can<?> other)     (43)
  boolean startsWith(Can<?> other)     (44)
  boolean endsWith(Can<?> other)     (45)
  boolean isEmpty()
  boolean isNotEmpty()
  boolean isCardinalityOne()
  boolean isCardinalityMultiple()
  Collector<T, ?, Can<T>> toCan()
  List<T> toList()     (46)
  List<T> toArrayList()     (47)
  Set<T> toSet()     (48)
  Set<T> toSet(Consumer<T> onDuplicated)     (49)
  T[] toArray(T[] a)     (50)
  T[] toArray(Class<T> elementType)     (51)
  Map<K, T> toMap(Function<? super T, ? extends K> keyExtractor)     (52)
  Map<K, T> toMap(Function<? super T, ? extends K> keyExtractor, BinaryOperator<T> mergeFunction, Supplier<M> mapFactory)     (53)
  R collect(Collector<? super T, A, R> collector)     (54)
  Map<K, Can<T>> groupBy(Function<? super T, ? extends K> classifier)     (55)
  Map<K, Can<T>> groupBy(Function<? super T, ? extends K> classifier, Supplier<M> mapFactory)     (56)
  String join(String delimiter)     (57)
  String join(Function<? super T, String> toStringFunction, String delimiter)     (58)
}
1 get(int)

Will (only ever) return an empty Optional , if the elementIndex is out of bounds.

2 getRelativeToLast(int)

Shortcut for get(this.size() - 1 - (-offset))

3 getElseFail(int)

Shortcut to get(elementIndex).orElseThrow(…​)

4 getRelativeToLastElseFail(int)

Shortcut for getElseFail(this.size() - 1 - (-offset))

5 compareTo(Can)

For convenience allows the argument to be null treating null equivalent to Can#empty() .

6 getFirst()
7 getFirstElseFail()

Shortcut for getFirst().orElseThrow(_Exceptions::noSuchElement)

8 getLast()
9 getLastElseFail()

Shortcut for getLast().orElseThrow(_Exceptions::noSuchElement)

10 empty()

Returns an empty Can .

11 ofNullable(T)

Returns either a Can with the given element or an empty Can if the element is null .

12 ofSingleton(T)

Returns either a Can with the given element or throws if the element is null .

13 of(T)

Var-arg version of Can#ofArray(Object[]) .

14 ofArray(T)

Returns either a Can with all the elements from given array or an empty Can if the array is null .

15 ofCollection(Collection)

Returns either a Can with all the elements from given collection or an empty Can if the collection is null .

16 ofIterable(Iterable)

Returns either a Can with all the elements from given iterable or an empty Can if the iterable is null .

17 ofEnumeration(Enumeration)

Returns either a Can with all the elements from given enumeration or an empty Can if the enumeration is null .

18 ofStream(Stream)

Returns either a Can with all the elements from given stream or an empty Can if the stream is null .

19 sorted(Comparator)

Returns a Can with all the elements from this Can , but sorted based on Comparable#compareTo(Object) order.

20 distinct()

Returns a Can with all the elements from this Can , but duplicated elements removed, based on Object#equals(Object) object equality.

21 distinct(BiPredicate)

Returns a Can with all the elements from this Can , but duplicated elements removed, based on given equality relation.

22 reverse()

Returns a Can with all the elements from this Can , but contained in reversed order.

23 filter(Predicate)

Returns a Can with all the elements from this Can , that are accepted by the given predicate . If predicate is null all elements are accepted.

24 map(Function)

Returns a Can with all the elements from this Can 'transformed' by the given mapper function.

25 reduce(BinaryOperator)

Performs a reduction on all elements, returning a Can containing either a singleton reduction result or an empty Can .

26 concat(Can, T)

Returns a Can with all the elements from given can joined by the given element . If any of given can or element are null these do not contribute any elements and are ignored.

27 iterator(int, int)

Returns an iterator that skips the first skip elements, then returns a maximum of limit elements.

28 zip(Iterable, BiConsumer)

Similar to #forEach(Consumer) , but zips in zippedIn to iterate through its elements and passes them over as the second argument to the action .

29 zipMap(Iterable, BiFunction)

Similar to #map(Function) , but zips in zippedIn to iterate through its elements and passes them over as the second argument to the mapper .

30 zipStream(Iterable, BiFunction)

Semantically equivalent to #zipMap(Iterable, BiFunction) .stream().

31 addUnique(T)

Adds the specified element to the list if it is not already present.

32 add(int, T)

Inserts the specified element at the specified position in this list (optional operation). Shifts the element currently at that position (if any) and any subsequent elements to the right (adds one to their indices).

33 remove(int)

Removes the element at the specified position in this list (optional operation). Shifts any subsequent elements to the left (subtracts one from their indices). Returns the element that was removed from the list.

34 pickByIndex(int)

Given n indices, returns an equivalent of(where nulls are being ignored)

35 pickByIndex(IntStream)

Returns a Can that is made of the elements from this Can , picked by index using the given IntStream (in the order of picking).

36 subCan(int)

Returns a sub- Can that is made of elements from this Can , starting with indices from startInclusive .

37 subCan(int, int)

Returns a sub- Can that is made of elements from this Can , when selected by indices from given range [startInclusive, endExclusive) .

38 partitionInnerBound(int)

Returns consecutive #subCan(int, int) subCan , each of the same maxInnerSize, while the final sub- Can may be smaller.

39 partitionOuterBound(int)

Tries to split this Can into outerSizeYield consecutive #subCan(int, int) subCan , each of the same calculated max-inner-size, while the final sub- Can may be smaller.

40 indexOf(T)

Returns the index of the first occurrence of the specified element in this list, or -1 if this list does not contain the element. More formally, returns the lowest index i such that (o==null ? get(i)==null : o.equals(get(i))) , or -1 if there is no such index.

41 anyMatch(Predicate)

Returns whether any elements of this Can match the provided predicate.

42 allMatch(Predicate)

Returns whether all elements of this stream match the provided predicate.

43 isEqualTo(Can)
44 startsWith(Can)

Let n be the number of elements in other . Returns whether the first n elements of this Can are element-wise equal to other .

45 endsWith(Can)

Let n be the number of elements in other . Returns whether the last n elements of this Can are element-wise equal to other .

46 toList()
47 toArrayList()
48 toSet()
49 toSet(Consumer)
50 toArray(T)
51 toArray(Class)
52 toMap(Function)

Returns a Map with values from this Can , and keys as produced by given keyExtractor .

53 toMap(Function, BinaryOperator, Supplier)

Returns a Map with values from this Can , and keys as produced by given keyExtractor .

54 collect(Collector)

Semantically equivalent to #stream() . Stream#collect(Collector) collect(collector) .

55 groupBy(Function)

Groups elements of this Can into a multi-valued Map , according to given classification function.

56 groupBy(Function, Supplier)

Groups elements of this Can into a multi-valued Map , according to given classification function.

57 join(String)

Semantically equivalent to #map(Function) map(Object::toString)_.collect(Collectors.joining(delimiter));_

58 join(Function, String)

Semantically equivalent to #map(Function) map(toStringFunction)_.collect(Collectors.joining(delimiter));_

Members

get(int)

Will (only ever) return an empty Optional , if the elementIndex is out of bounds.

getRelativeToLast(int)

Shortcut for get(this.size() - 1 - (-offset))

getElseFail(int)

Shortcut to get(elementIndex).orElseThrow(…​)

Will only ever throw, if the elementIndex is out of bounds.

getRelativeToLastElseFail(int)

Shortcut for getElseFail(this.size() - 1 - (-offset))

compareTo(Can)

For convenience allows the argument to be null treating null equivalent to Can#empty() .

getFirst()

getFirstElseFail()

Shortcut for getFirst().orElseThrow(_Exceptions::noSuchElement)

getLast()

getLastElseFail()

Shortcut for getLast().orElseThrow(_Exceptions::noSuchElement)

empty()

Returns an empty Can .

ofNullable(T)

Returns either a Can with the given element or an empty Can if the element is null .

ofSingleton(T)

Returns either a Can with the given element or throws if the element is null .

of(T)

Var-arg version of Can#ofArray(Object[]) .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .

ofArray(T)

Returns either a Can with all the elements from given array or an empty Can if the array is null .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .

ofCollection(Collection)

Returns either a Can with all the elements from given collection or an empty Can if the collection is null .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .

ofIterable(Iterable)

Returns either a Can with all the elements from given iterable or an empty Can if the iterable is null .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .

ofEnumeration(Enumeration)

Returns either a Can with all the elements from given enumeration or an empty Can if the enumeration is null .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .
*NOTE:* As side-effect, consumes given _enumeration_ .

ofStream(Stream)

Returns either a Can with all the elements from given stream or an empty Can if the stream is null .

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .
*NOTE:* As side-effect, consumes given _stream_ .

sorted(Comparator)

Returns a Can with all the elements from this Can , but sorted based on Comparable#compareTo(Object) order.

distinct()

Returns a Can with all the elements from this Can , but duplicated elements removed, based on Object#equals(Object) object equality.

distinct(BiPredicate)

Returns a Can with all the elements from this Can , but duplicated elements removed, based on given equality relation.

reverse()

Returns a Can with all the elements from this Can , but contained in reversed order.

filter(Predicate)

Returns a Can with all the elements from this Can , that are accepted by the given predicate . If predicate is null all elements are accepted.

map(Function)

Returns a Can with all the elements from this Can 'transformed' by the given mapper function.

*NOTE:* Any elements equal to _null_ are ignored and will not be contained in the resulting _Can_ .

reduce(BinaryOperator)

Performs a reduction on all elements, returning a Can containing either a singleton reduction result or an empty Can .

concat(Can, T)

Returns a Can with all the elements from given can joined by the given element . If any of given can or element are null these do not contribute any elements and are ignored.

iterator(int, int)

Returns an iterator that skips the first skip elements, then returns a maximum of limit elements.

zip(Iterable, BiConsumer)

Similar to #forEach(Consumer) , but zips in zippedIn to iterate through its elements and passes them over as the second argument to the action .

zipMap(Iterable, BiFunction)

Similar to #map(Function) , but zips in zippedIn to iterate through its elements and passes them over as the second argument to the mapper .

zipStream(Iterable, BiFunction)

Semantically equivalent to #zipMap(Iterable, BiFunction) .stream().

(Actual implementations might be optimized.)

addUnique(T)

Adds the specified element to the list if it is not already present.

add(int, T)

Inserts the specified element at the specified position in this list (optional operation). Shifts the element currently at that position (if any) and any subsequent elements to the right (adds one to their indices).

remove(int)

Removes the element at the specified position in this list (optional operation). Shifts any subsequent elements to the left (subtracts one from their indices). Returns the element that was removed from the list.

pickByIndex(int)

Given n indices, returns an equivalent of(where nulls are being ignored)

Can.of(
    this.get(indices[0]).orElse(null),
    this.get(indices[1]).orElse(null),
    ...
    this.get(indices[n-1]).orElse(null)
)

In other words: Out of bounds picking is simply ignored.

pickByIndex(IntStream)

Returns a Can that is made of the elements from this Can , picked by index using the given IntStream (in the order of picking).

Out of bounds picking is simply ignored.

subCan(int)

Returns a sub- Can that is made of elements from this Can , starting with indices from startInclusive .

Out of bounds picking is simply ignored.

subCan(int, int)

Returns a sub- Can that is made of elements from this Can , when selected by indices from given range [startInclusive, endExclusive) .

Out of bounds picking is simply ignored.

partitionInnerBound(int)

Returns consecutive #subCan(int, int) subCan , each of the same maxInnerSize, while the final sub- Can may be smaller.

For example, partitioning a Can containing [a, b, c, d, e] with a partition size of 3 yields  — an outer Can containing two inner Can s of three and two elements, all in the original order.

partitionOuterBound(int)

Tries to split this Can into outerSizeYield consecutive #subCan(int, int) subCan , each of the same calculated max-inner-size, while the final sub- Can may be smaller.

An outer cardinality of outerSizeYield is either exactly met or under-represented, based on how many elements are actually available.

indexOf(T)

Returns the index of the first occurrence of the specified element in this list, or -1 if this list does not contain the element. More formally, returns the lowest index i such that (o==null ? get(i)==null : o.equals(get(i))) , or -1 if there is no such index.

anyMatch(Predicate)

Returns whether any elements of this Can match the provided predicate.

allMatch(Predicate)

Returns whether all elements of this stream match the provided predicate.

isEqualTo(Can)

startsWith(Can)

Let n be the number of elements in other . Returns whether the first n elements of this Can are element-wise equal to other .

endsWith(Can)

Let n be the number of elements in other . Returns whether the last n elements of this Can are element-wise equal to other .

toList()

toArrayList()

toSet()

toSet(Consumer)

toArray(T)

toArray(Class)

toMap(Function)

Returns a Map with values from this Can , and keys as produced by given keyExtractor .

The result is protected from modification. (If you instead need a modifiable result, use the #collect(Collector) method.)

On duplicate keys, behavior is unspecified.

toMap(Function, BinaryOperator, Supplier)

Returns a Map with values from this Can , and keys as produced by given keyExtractor .

The result is protected from modification. (If you instead need a modifiable result, use the #collect(Collector) method.)

collect(Collector)

Semantically equivalent to #stream() . Stream#collect(Collector) collect(collector) .

(Actual implementations might be optimized.)

Whether the result is protected from modification, is up to given Collector .

groupBy(Function)

Groups elements of this Can into a multi-valued Map , according to given classification function.

The result is protected from modification. (If you instead need a modifiable result, use the #collect(Collector) method.)

groupBy(Function, Supplier)

Groups elements of this Can into a multi-valued Map , according to given classification function.

The result is protected from modification. (If you instead need a modifiable result, use the #collect(Collector) method.)

join(String)

Semantically equivalent to #map(Function) map(Object::toString)_.collect(Collectors.joining(delimiter));_

(Actual implementations might be optimized.)

join(Function, String)

Semantically equivalent to #map(Function) map(toStringFunction)_.collect(Collectors.joining(delimiter));_

(Actual implementations might be optimized.)