|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.commons.collections.collection.AbstractCollectionDecorator org.apache.commons.collections.list.AbstractListDecorator org.apache.commons.collections.list.AbstractSerializableListDecorator org.apache.commons.collections.list.GrowthList
public class GrowthList
Decorates another List
to make it seamlessly grow when
indices larger than the list size are used on add and set,
avoiding most IndexOutOfBoundsExceptions.
This class avoids errors by growing when a set or add method would normally throw an IndexOutOfBoundsException. Note that IndexOutOfBoundsException IS returned for invalid negative indices.
Trying to set or add to an index larger than the size will cause the list
to grow (using null
elements). Clearly, care must be taken
not to use excessively large indices, as the internal list will grow to
match.
Trying to use any method other than add or set with an invalid index will call the underlying list and probably result in an IndexOutOfBoundsException.
Take care when using this list with null
values, as
null
is the value added when growing the list.
All sub-lists will access the underlying list directly, and will throw IndexOutOfBoundsExceptions.
This class differs from LazyList
because here growth occurs on
set and add, where LazyList
grows on get. However, they
can be used together by decorating twice.
LazyList
,
Serialized FormField Summary |
---|
Fields inherited from class org.apache.commons.collections.collection.AbstractCollectionDecorator |
---|
collection |
Constructor Summary | |
---|---|
|
GrowthList()
Constructor that uses an ArrayList internally. |
|
GrowthList(int initialSize)
Constructor that uses an ArrayList internally. |
protected |
GrowthList(java.util.List list)
Constructor that wraps (not copies). |
Method Summary | |
---|---|
void |
add(int index,
java.lang.Object element)
Decorate the add method to perform the growth behaviour. |
boolean |
addAll(int index,
java.util.Collection coll)
Decorate the addAll method to perform the growth behaviour. |
static java.util.List |
decorate(java.util.List list)
Factory method to create a growth list. |
java.lang.Object |
set(int index,
java.lang.Object element)
Decorate the set method to perform the growth behaviour. |
Methods inherited from class org.apache.commons.collections.list.AbstractListDecorator |
---|
get, getList, indexOf, lastIndexOf, listIterator, listIterator, remove, subList |
Methods inherited from class org.apache.commons.collections.collection.AbstractCollectionDecorator |
---|
add, addAll, clear, contains, containsAll, equals, getCollection, hashCode, isEmpty, iterator, remove, removeAll, retainAll, size, toArray, toArray, toString |
Methods inherited from class java.lang.Object |
---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
Methods inherited from interface java.util.List |
---|
add, addAll, clear, contains, containsAll, equals, hashCode, isEmpty, iterator, remove, removeAll, retainAll, size, toArray, toArray |
Constructor Detail |
---|
public GrowthList()
public GrowthList(int initialSize)
initialSize
- the initial size of the ArrayList
java.lang.IllegalArgumentException
- if initial size is invalidprotected GrowthList(java.util.List list)
list
- the list to decorate, must not be null
java.lang.IllegalArgumentException
- if list is nullMethod Detail |
---|
public static java.util.List decorate(java.util.List list)
list
- the list to decorate, must not be null
java.lang.IllegalArgumentException
- if list is nullpublic void add(int index, java.lang.Object element)
If the requested index is greater than the current size, the list will
grow to the new size. Indices between the old size and the requested
size will be filled with null
.
If the index is less than the current size, the value will be added to the underlying list directly. If the index is less than zero, the underlying list is called, which will probably throw an IndexOutOfBoundsException.
add
in interface java.util.List
add
in class AbstractListDecorator
index
- the index to add atelement
- the object to add at the specified index
java.lang.UnsupportedOperationException
- if the underlying list doesn't implement set
java.lang.ClassCastException
- if the underlying list rejects the element
java.lang.IllegalArgumentException
- if the underlying list rejects the elementpublic boolean addAll(int index, java.util.Collection coll)
If the requested index is greater than the current size, the list will
grow to the new size. Indices between the old size and the requested
size will be filled with null
.
If the index is less than the current size, the values will be added to the underlying list directly. If the index is less than zero, the underlying list is called, which will probably throw an IndexOutOfBoundsException.
addAll
in interface java.util.List
addAll
in class AbstractListDecorator
index
- the index to add atcoll
- the collection to add at the specified index
java.lang.UnsupportedOperationException
- if the underlying list doesn't implement set
java.lang.ClassCastException
- if the underlying list rejects the element
java.lang.IllegalArgumentException
- if the underlying list rejects the elementpublic java.lang.Object set(int index, java.lang.Object element)
If the requested index is greater than the current size, the list will
grow to the new size. Indices between the old size and the requested
size will be filled with null
.
If the index is less than the current size, the value will be set onto the underlying list directly. If the index is less than zero, the underlying list is called, which will probably throw an IndexOutOfBoundsException.
set
in interface java.util.List
set
in class AbstractListDecorator
index
- the index to setelement
- the object to set at the specified index
java.lang.UnsupportedOperationException
- if the underlying list doesn't implement set
java.lang.ClassCastException
- if the underlying list rejects the element
java.lang.IllegalArgumentException
- if the underlying list rejects the element
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |