Class PaginatedList<T>
- java.lang.Object
-
- com.amazonaws.services.dynamodbv2.datamodeling.PaginatedList<T>
-
- Type Parameters:
T- The domain object type stored in this list.
- All Implemented Interfaces:
Iterable<T>,Collection<T>,List<T>
- Direct Known Subclasses:
PaginatedParallelScanList,PaginatedQueryList,PaginatedScanList
public abstract class PaginatedList<T> extends Object implements List<T>
Unmodifiable list supporting paginated result sets from Amazon DynamoDB.Pages of results are fetched lazily from DynamoDB as they are needed. Some methods, such as
size()andtoArray(), require fetching the entire result set eagerly. See the javadoc of individual methods for details on which are lazy.
-
-
Field Summary
Fields Modifier and Type Field Description protected List<T>allResultsAll currently loaded results for this list.protected booleanallResultsLoadedTracks if all results have been loaded yet or notprotected Class<T>clazzThe class annotated with DynamoDB tags declaring how to load/store objects into DynamoDBprotected AmazonDynamoDBdynamoThe client for working with DynamoDBprotected DynamoDBMappermapperReference to the DynamoDB mapper for marshalling DynamoDB attributes back into objectsprotected List<T>nextResultsLazily loaded next results waiting to be added into allResults
-
Constructor Summary
Constructors Constructor Description PaginatedList(DynamoDBMapper mapper, Class<T> clazz, AmazonDynamoDB dynamo)Constructs a PaginatedList instance using the default PaginationLoadingStrategyPaginatedList(DynamoDBMapper mapper, Class<T> clazz, AmazonDynamoDB dynamo, DynamoDBMapperConfig.PaginationLoadingStrategy paginationLoadingStrategy)Constructs a PaginatedList instance.
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidadd(int arg0, T arg1)booleanadd(T arg0)booleanaddAll(int arg0, Collection<? extends T> arg1)booleanaddAll(Collection<? extends T> arg0)protected abstract booleanatEndOfResults()Returns whether we have reached the end of the result set.voidclear()booleancontains(Object arg0)Returns whether the collection contains the given element.booleancontainsAll(Collection<?> arg0)protected abstract List<T>fetchNextPage()Fetches the next page of results (which may be empty) and returns any items found.Tget(int n)Returns the Nth element of the list.intindexOf(Object arg0)Returns the first index of the object given in the list.booleanisEmpty()Returns whether the collection is empty.Iterator<T>iterator()Returns an iterator over this list that lazily initializes results as necessary.intlastIndexOf(Object arg0)ListIterator<T>listIterator()ListIterator<T>listIterator(int arg0)voidloadAllResults()Eagerly loads all results for this list.Tremove(int arg0)booleanremove(Object arg0)booleanremoveAll(Collection<?> arg0)booleanretainAll(Collection<?> arg0)Tset(int arg0, T arg1)intsize()List<T>subList(int arg0, int arg1)Returns a sub-list in the range specified, loading more results as necessary.Object[]toArray()<X> X[]toArray(X[] a)-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface java.util.Collection
parallelStream, removeIf, stream, toArray
-
Methods inherited from interface java.util.List
equals, hashCode, replaceAll, sort, spliterator
-
-
-
-
Field Detail
-
mapper
protected final DynamoDBMapper mapper
Reference to the DynamoDB mapper for marshalling DynamoDB attributes back into objects
-
clazz
protected final Class<T> clazz
The class annotated with DynamoDB tags declaring how to load/store objects into DynamoDB
-
dynamo
protected final AmazonDynamoDB dynamo
The client for working with DynamoDB
-
allResultsLoaded
protected boolean allResultsLoaded
Tracks if all results have been loaded yet or not
-
allResults
protected final List<T> allResults
All currently loaded results for this list. In ITERATION_ONLY mode, this list will at most keep one page of the loaded results, and all previous results will be cleared from the memory.
-
-
Constructor Detail
-
PaginatedList
public PaginatedList(DynamoDBMapper mapper, Class<T> clazz, AmazonDynamoDB dynamo)
Constructs a PaginatedList instance using the default PaginationLoadingStrategy
-
PaginatedList
public PaginatedList(DynamoDBMapper mapper, Class<T> clazz, AmazonDynamoDB dynamo, DynamoDBMapperConfig.PaginationLoadingStrategy paginationLoadingStrategy)
Constructs a PaginatedList instance.- Parameters:
mapper- The mapper for marshalling DynamoDB attributes into objects.clazz- The class of the annotated model.dynamo- The DynamoDB client for making low-level request calls.paginationLoadingStrategy- The strategy used for loading paginated results. Caller has to explicitly set this parameter, since the DynamoDBMapperConfig set in the mapper is not accessible here. If null value is provided, LAZY_LOADING will be set by default.
-
-
Method Detail
-
loadAllResults
public void loadAllResults()
Eagerly loads all results for this list.Not supported in ITERATION_ONLY mode.
-
fetchNextPage
protected abstract List<T> fetchNextPage()
Fetches the next page of results (which may be empty) and returns any items found.
-
atEndOfResults
protected abstract boolean atEndOfResults()
Returns whether we have reached the end of the result set.
-
iterator
public Iterator<T> iterator()
Returns an iterator over this list that lazily initializes results as necessary.If it configured with ITERARTION_ONLY mode, then the iterator could be only retrieved once, and any previously loaded results will be cleared in the memory during the iteration.
-
isEmpty
public boolean isEmpty()
Returns whether the collection is empty. At most one (non-empty) page of results is loaded to make the check.Not supported in ITERATION_ONLY mode.
-
get
public T get(int n)
Returns the Nth element of the list. Results are loaded until N elements are present, if necessary.Not supported in ITERATION_ONLY mode.
-
contains
public boolean contains(Object arg0)
Returns whether the collection contains the given element. Results are loaded and checked incrementally until a match is found or the end of the result set is reached.Not supported in ITERATION_ONLY mode.
-
subList
public List<T> subList(int arg0, int arg1)
Returns a sub-list in the range specified, loading more results as necessary.Not supported in ITERATION_ONLY mode.
-
indexOf
public int indexOf(Object arg0)
Returns the first index of the object given in the list. Additional results are loaded incrementally as necessary.Not supported in ITERATION_ONLY mode.
-
size
public int size()
-
containsAll
public boolean containsAll(Collection<?> arg0)
- Specified by:
containsAllin interfaceCollection<T>- Specified by:
containsAllin interfaceList<T>
-
lastIndexOf
public int lastIndexOf(Object arg0)
- Specified by:
lastIndexOfin interfaceList<T>
-
toArray
public Object[] toArray()
-
toArray
public <X> X[] toArray(X[] a)
-
listIterator
public ListIterator<T> listIterator()
- Specified by:
listIteratorin interfaceList<T>
-
listIterator
public ListIterator<T> listIterator(int arg0)
- Specified by:
listIteratorin interfaceList<T>
-
remove
public boolean remove(Object arg0)
-
removeAll
public boolean removeAll(Collection<?> arg0)
-
retainAll
public boolean retainAll(Collection<?> arg0)
-
add
public boolean add(T arg0)
-
addAll
public boolean addAll(Collection<? extends T> arg0)
-
addAll
public boolean addAll(int arg0, Collection<? extends T> arg1)
-
-