Class FinalSet<T extends Comparable<?>>
- java.lang.Object
-
- java.util.AbstractCollection<E>
-
- java.util.AbstractList<T>
-
- com.ethlo.zally.rules.common.FinalSet<T>
-
- All Implemented Interfaces:
Iterable<T>,Collection<T>,List<T>,Set<T>
public class FinalSet<T extends Comparable<?>> extends AbstractList<T> implements Set<T>
Copyright 2016 Fabian M. SuchanekLicensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
This class provides a very simple container implementation with zero overhead. A FinalSet bases on a sorted, unmodifiable array. The constructor can either be called with a sorted unmodifiable array (default constructor) or with an array that can be cloned and sorted beforehand if desired. Example:
FinalSet<String> f=new FinalSet("a","b","c"); // equivalently: // FinalSet<String> f=new FinalSet(new String[]{"a","b","c"}); // FinalSet<String> f=new FinalSet(SHALLNOTBECLONED,ISSORTED,"a","b","c"); System.out.println(f.get(1)); --> b
-
-
Field Summary
Fields Modifier and Type Field Description T[]dataHolds the data, must be sorted-
Fields inherited from class java.util.AbstractList
modCount
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancontains(T x)Tells whether x is in the containerTget(int i)Returns the element at position iintindexOf(T x)Returns the position in the array or -1intsize()Returns the number of elements in this FinalSetSpliterator<T>spliterator()-
Methods inherited from class java.util.AbstractList
add, add, addAll, clear, equals, hashCode, indexOf, iterator, lastIndexOf, listIterator, listIterator, remove, removeRange, set, subList
-
Methods inherited from class java.util.AbstractCollection
addAll, contains, containsAll, isEmpty, remove, removeAll, retainAll, toArray, toArray, toString
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Collection
parallelStream, removeIf, stream, toArray
-
-
-
-
Field Detail
-
data
public T extends Comparable<?>[] data
Holds the data, must be sorted
-
-
Method Detail
-
contains
public boolean contains(T x)
Tells whether x is in the container
-
indexOf
public int indexOf(T x)
Returns the position in the array or -1
-
get
public T get(int i)
Returns the element at position i- Specified by:
getin interfaceList<T extends Comparable<?>>- Specified by:
getin classAbstractList<T extends Comparable<?>>
-
size
public int size()
Returns the number of elements in this FinalSet- Specified by:
sizein interfaceCollection<T extends Comparable<?>>- Specified by:
sizein interfaceList<T extends Comparable<?>>- Specified by:
sizein interfaceSet<T extends Comparable<?>>- Specified by:
sizein classAbstractCollection<T extends Comparable<?>>
-
spliterator
public Spliterator<T> spliterator()
- Specified by:
spliteratorin interfaceCollection<T extends Comparable<?>>- Specified by:
spliteratorin interfaceIterable<T extends Comparable<?>>- Specified by:
spliteratorin interfaceList<T extends Comparable<?>>- Specified by:
spliteratorin interfaceSet<T extends Comparable<?>>
-
-