T
- type of list element.public class BlockList<T> extends AbstractList<T>
Unlike ArrayList
, this type does not need to reallocate the
internal array in order to expand the capacity of the list. Access to any
element is constant time, but requires two array lookups instead of one.
To handle common usages, add(Object)
and iterator()
use
internal code paths to amortize out the second array lookup, making addition
and simple iteration closer to one array operation per element processed.
Similar to ArrayList
, adding or removing from any position except the
end of the list requires O(N) time to copy all elements between the
modification point and the end of the list. Applications are strongly
encouraged to not use this access pattern with this list implementation.
modCount
Constructor and Description |
---|
BlockList()
Initialize an empty list.
|
BlockList(int capacity)
Initialize an empty list with an expected capacity.
|
Modifier and Type | Method and Description |
---|---|
void |
add(int index,
T element) |
boolean |
add(T element) |
void |
addAll(BlockList<T> src)
Quickly append all elements of another BlockList.
|
void |
addAll(T[] src,
int srcIdx,
int srcCnt)
Quickly append all elements from an array.
|
void |
clear() |
T |
get(int index) |
Iterator<T> |
iterator() |
T |
remove(int index) |
T |
set(int index,
T element) |
int |
size() |
addAll, equals, hashCode, indexOf, lastIndexOf, listIterator, listIterator, removeRange, subList
addAll, contains, containsAll, isEmpty, remove, removeAll, retainAll, toArray, toArray, toString
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
addAll, contains, containsAll, isEmpty, remove, removeAll, replaceAll, retainAll, sort, spliterator, toArray, toArray
parallelStream, removeIf, stream
public BlockList()
public BlockList(int capacity)
capacity
- number of elements expected to be in the list.public int size()
size
in interface Collection<T>
size
in interface List<T>
size
in class AbstractCollection<T>
public void clear()
clear
in interface Collection<T>
clear
in interface List<T>
clear
in class AbstractList<T>
public T get(int index)
public void addAll(BlockList<T> src)
src
- the list to copy elements from.public void addAll(T[] src, int srcIdx, int srcCnt)
src
- the source array.srcIdx
- first index to copy.srcCnt
- number of elements to copy.public boolean add(T element)
add
in interface Collection<T>
add
in interface List<T>
add
in class AbstractList<T>
public void add(int index, T element)
public T remove(int index)
Copyright © 2018 Eclipse JGit Project. All rights reserved.