public class LazyList<E> extends AbstractList<E> implements RandomAccess
A lazy list and uses a ListAccess object to load
the elements of the list. The list is read only and any write access to the list will
not be permitted.
The loading policy is based on a simple batch algorithm that loads the elements by batches.
The list also keeps a cache of the retrieved elements. The cache use soft references to provide eviction of the elements if necessary. When a soft reference is cleared and access is made to an evicted element then the elements will be reloaded from the list access object.
If the list access fails to load a batch by throwing a checked exception, it will cause the
list to throw an IllegalStateException wrapping the original exception. Any other kind
of non checked throwable will be propagated to the caller as it is.
The implementation does not perform any kind of versionning check of the underlying data and if the underlying list access changes the state it exposes the lazy list will not be aware of it and may behave in an unexpected manner.
modCount| Constructor and Description |
|---|
LazyList(ListAccess<E> listAccess,
int batchSize) |
| Modifier and Type | Method and Description |
|---|---|
E |
get(int index) |
int |
size() |
add, add, addAll, clear, equals, hashCode, indexOf, iterator, lastIndexOf, listIterator, listIterator, remove, removeRange, set, subListaddAll, contains, containsAll, isEmpty, remove, removeAll, retainAll, toArray, toArray, toStringclone, finalize, getClass, notify, notifyAll, wait, wait, waitaddAll, contains, containsAll, isEmpty, remove, removeAll, replaceAll, retainAll, sort, spliterator, toArray, toArrayparallelStream, removeIf, streampublic LazyList(ListAccess<E> listAccess, int batchSize)
Copyright © 2016 eXo Platform SAS. All Rights Reserved.