Package jadex.commons.collection
Class WeakList<E>
- java.lang.Object
- 
- jadex.commons.collection.WeakList<E>
 
- 
- All Implemented Interfaces:
- java.io.Serializable,- java.lang.Iterable<E>,- java.util.Collection<E>,- java.util.List<E>
 
 public class WeakList<E> extends java.lang.Object implements java.util.List<E>, java.io.SerializableA list with weak entries.- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected java.lang.ref.Reference<E>[]arrayThe list of elements.protected java.lang.ref.ReferenceQueuequeueReference queue for garbage-collected elements.protected java.util.List<E>serialized_listprotected intsizeThe number of elements.protected intstateThe state (to check for modifications).
 - 
Constructor SummaryConstructors Constructor Description WeakList()Create a new list.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(int index, java.lang.Object o)Inserts the specified element at the specified position in this list (optional operation).booleanadd(E o)Appends the specified element to the end of this list (optional operation).booleanaddAll(int index, java.util.Collection collection)Inserts all of the elements in the specified collection into this list at the specified position (optional operation).booleanaddAll(java.util.Collection collection)Appends all of the elements in the specified collection to the end of this list, in the order that they are returned by the specified collection's iterator (optional operation).protected static voidcheckForEmptySlots(java.util.List list)Check for empty slots in list.voidclear()Removes all of the elements from this list (optional operation).booleancontains(java.lang.Object o)ReturnsbooleancontainsAll(java.util.Collection c)Returnsprotected static java.lang.String[]createTestvalues(java.lang.String teststring, int size)Create some string values for testing.Eget(int index)Returns the element at the specified position in this list.intindexOf(java.lang.Object o)Returns the index in this list of the first occurrence of the specified element, or -1 if this list does not contain this element.booleanisEmpty()Returnsjava.util.Iterator<E>iterator()Returns an iterator over the elements in this list in proper sequence.intlastIndexOf(java.lang.Object o)Returns the index in this list of the last occurrence of the specified element, or -1 if this list does not contain this element.java.util.ListIterator<E>listIterator()Returns a list iterator of the elements in this list (in proper sequence).java.util.ListIterator<E>listIterator(int index)Returns a list iterator of the elements in this list (in proper sequence), starting at the specified position in this list.static voidmain(java.lang.String[] args)Main method for testing.protected java.lang.ObjectreadResolve()Perform special handling on deserialization.Eremove(int index)Removes the element at the specified position in this list (optional operation).booleanremove(java.lang.Object o)Removes the first occurrence in this list of the specified element (optional operation).booleanremoveAll(java.util.Collection c)Removes from this list all the elements that are contained in the specified collection (optional operation).booleanretainAll(java.util.Collection c)Retains only the elements in this list that are contained in the specified collection (optional operation).java.lang.Objectset(int index, java.lang.Object o)Replaces the element at the specified position in this list with the specified element (optional operation).intsize()Returns the number of elements in this list.java.util.List<E>subList(int fromIndex, int toIndex)Returns a view of the portion of this list between the specifiedjava.lang.Object[]toArray()Returns an array containing all of the elements in this list in proper sequence.java.lang.Object[]toArray(java.lang.Object[] ret)Returns an array containing all of the elements in this list in proper sequence; the runtime type of the returned array is that of the specified array.java.lang.StringtoString()Get the string representation.protected java.lang.ObjectwriteReplace()Perform special handling on serialization.
 
- 
- 
- 
Field Detail- 
arrayprotected transient java.lang.ref.Reference<E>[] array The list of elements.
 - 
sizeprotected int size The number of elements.
 - 
stateprotected int state The state (to check for modifications).
 - 
queueprotected transient java.lang.ref.ReferenceQueue queue Reference queue for garbage-collected elements.
 - 
serialized_listprotected java.util.List<E> serialized_list 
 
- 
 - 
Method Detail- 
sizepublic int size() Returns the number of elements in this list. If this list contains more than- Specified by:
- sizein interface- java.util.Collection<E>
- Specified by:
- sizein interface- java.util.List<E>
- Returns:
- the number of elements in this list.
 - 
isEmptypublic boolean isEmpty() Returns- Specified by:
- isEmptyin interface- java.util.Collection<E>
- Specified by:
- isEmptyin interface- java.util.List<E>
- Returns:
 - 
containspublic boolean contains(java.lang.Object o) Returns- Specified by:
- containsin interface- java.util.Collection<E>
- Specified by:
- containsin interface- java.util.List<E>
- Parameters:
- o- element whose presence in this list is to be tested.
- Returns:
- 
- Throws:
java.lang.ClassCastException- if the type of the specified element is incompatible with this list (optional).java.lang.NullPointerException- if the specified element is null.
 - 
iteratorpublic java.util.Iterator<E> iterator() Returns an iterator over the elements in this list in proper sequence. Can handle garbage collection of elements, but fails fast in the presence of concurrent modifications.
 - 
toArraypublic java.lang.Object[] toArray() Returns an array containing all of the elements in this list in proper sequence. Obeys the general contract of the- Specified by:
- toArrayin interface- java.util.Collection<E>
- Specified by:
- toArrayin interface- java.util.List<E>
- Returns:
- an array containing all of the elements in this list in proper sequence.
- See Also:
- Arrays.asList(Object[])
 - 
toArraypublic java.lang.Object[] toArray(java.lang.Object[] ret) Returns an array containing all of the elements in this list in proper sequence; the runtime type of the returned array is that of the specified array. Obeys the general contract of the- Specified by:
- toArrayin interface- java.util.Collection<E>
- Specified by:
- toArrayin interface- java.util.List<E>
- Parameters:
- ret- the array into which the elements of this list are to be stored, if it is big enough; otherwise, a new array of the same runtime type is allocated for this purpose.
- Returns:
- an array containing the elements of this list.
- Throws:
- java.lang.ArrayStoreException- if the runtime type of the specified array is not a supertype of the runtime type of every element in this list.
- java.lang.NullPointerException- if the specified array is
 - 
addpublic boolean add(E o) Appends the specified element to the end of this list (optional operation).- Specified by:
- addin interface- java.util.Collection<E>
- Specified by:
- addin interface- java.util.List<E>
- Parameters:
- o- element to be appended to this list.
- Returns:
- 
- Throws:
java.lang.UnsupportedOperationException- if thejava.lang.ClassCastException- if the class of the specified element prevents it from being added to this list.java.lang.NullPointerException- if the specified element is nul.java.lang.IllegalArgumentException- if some aspect of this element prevents it from being added to this list.
 - 
removepublic boolean remove(java.lang.Object o) Removes the first occurrence in this list of the specified element (optional operation). If this list does not contain the element, it is unchanged. More formally, removes the element with the lowest index i such that- Specified by:
- removein interface- java.util.Collection<E>
- Specified by:
- removein interface- java.util.List<E>
- Parameters:
- o- element to be removed from this list, if present.
- Returns:
- 
- Throws:
java.lang.ClassCastException- if the type of the specified element is incompatible with this list (optional).java.lang.NullPointerException- if the specified element is null.java.lang.UnsupportedOperationException- if the
 - 
containsAllpublic boolean containsAll(java.util.Collection c) Returns- Specified by:
- containsAllin interface- java.util.Collection<E>
- Specified by:
- containsAllin interface- java.util.List<E>
- Parameters:
- c- collection to be checked for containment in this list.
- Returns:
- 
- Throws:
java.lang.ClassCastException- if the types of one or more elements in the specified collection are incompatible with this list (optional).java.lang.NullPointerException- if the specified collection contains one or more null elements and this list does not support null elements (optional).java.lang.NullPointerException- if the specified collection is
- See Also:
contains(Object)
 - 
addAllpublic boolean addAll(java.util.Collection collection) Appends all of the elements in the specified collection to the end of this list, in the order that they are returned by the specified collection's iterator (optional operation). The behavior of this operation is unspecified if the specified collection is modified while the operation is in progress. (Note that this will occur if the specified collection is this list, and it's nonempty.)- Specified by:
- addAllin interface- java.util.Collection<E>
- Specified by:
- addAllin interface- java.util.List<E>
- Parameters:
- collection- collection whose elements are to be added to this list.
- Returns:
- 
- Throws:
java.lang.UnsupportedOperationException- if thejava.lang.ClassCastException- if the class of an element in the specified collection prevents it from being added to this list.java.lang.NullPointerException- if the specified collection contains one or more null elements and this list does not support null elements, or if the specified collection isjava.lang.IllegalArgumentException- if some aspect of an element in the specified collection prevents it from being added to this list.
- See Also:
add(Object)
 
 - 
addAllpublic boolean addAll(int index, java.util.Collection collection)Inserts all of the elements in the specified collection into this list at the specified position (optional operation). Shifts the element currently at that position (if any) and any subsequent elements to the right (increases their indices). The new elements will appear in this list in the order that they are returned by the specified collection's iterator. The behavior of this operation is unspecified if the specified collection is modified while the operation is in progress. (Note that this will occur if the specified collection is this list, and it's nonempty.)- Specified by:
- addAllin interface- java.util.List<E>
- Parameters:
- index- index at which to insert first element from the specified collection.
- collection- elements to be inserted into this list.
- Returns:
- 
- Throws:
java.lang.UnsupportedOperationException- if thejava.lang.ClassCastException- if the class of one of elements of the specified collection prevents it from being added to this list.java.lang.NullPointerException- if the specified collection contains one or more null elements and this list does not support null elements, or if the specified collection isjava.lang.IllegalArgumentException- if some aspect of one of elements of the specified collection prevents it from being added to this list.java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index > size()).
 
 - 
removeAllpublic boolean removeAll(java.util.Collection c) Removes from this list all the elements that are contained in the specified collection (optional operation).- Specified by:
- removeAllin interface- java.util.Collection<E>
- Specified by:
- removeAllin interface- java.util.List<E>
- Parameters:
- c- collection that defines which elements will be removed from this list.
- Returns:
- 
- Throws:
java.lang.UnsupportedOperationException- if thejava.lang.ClassCastException- if the types of one or more elements in this list are incompatible with the specified collection (optional).java.lang.NullPointerException- if this list contains one or more null elements and the specified collection does not support null elements (optional).java.lang.NullPointerException- if the specified collection is
- See Also:
remove(Object),contains(Object)
 
 - 
retainAllpublic boolean retainAll(java.util.Collection c) Retains only the elements in this list that are contained in the specified collection (optional operation). In other words, removes from this list all the elements that are not contained in the specified collection.- Specified by:
- retainAllin interface- java.util.Collection<E>
- Specified by:
- retainAllin interface- java.util.List<E>
- Parameters:
- c- collection that defines which elements this set will retain.
- Returns:
- 
- Throws:
java.lang.UnsupportedOperationException- if thejava.lang.ClassCastException- if the types of one or more elements in this list are incompatible with the specified collection (optional).java.lang.NullPointerException- if this list contains one or more null elements and the specified collection does not support null elements (optional).java.lang.NullPointerException- if the specified collection is
- See Also:
remove(Object),contains(Object)
 
 - 
clearpublic void clear() Removes all of the elements from this list (optional operation). This list will be empty after this call returns (unless it throws an exception).
 - 
getpublic E get(int index) Returns the element at the specified position in this list.- Specified by:
- getin interface- java.util.List<E>
- Parameters:
- index- index of element to return.
- Returns:
- the element at the specified position in this list.
- Throws:
- java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index >= size()).
 
 - 
setpublic java.lang.Object set(int index, java.lang.Object o)Replaces the element at the specified position in this list with the specified element (optional operation).- Specified by:
- setin interface- java.util.List<E>
- Parameters:
- index- index of element to replace.
- o- element to be stored at the specified position.
- Returns:
- the element previously at the specified position.
- Throws:
- java.lang.UnsupportedOperationException- if the- java.lang.ClassCastException- if the class of the specified element prevents it from being added to this list.- java.lang.NullPointerException- if the specified element is null and this list does not support null elements.- java.lang.IllegalArgumentException- if some aspect of the specified element prevents it from being added to this list.- java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index >= size()).
 
 - 
addpublic void add(int index, java.lang.Object o)Inserts the specified element at the specified position in this list (optional operation). Shifts the element currently at that position (if any) and any subsequent elements to the right (adds one to their indices).- Specified by:
- addin interface- java.util.List<E>
- Parameters:
- index- index at which the specified element is to be inserted.
- o- element to be inserted.
- Throws:
- java.lang.UnsupportedOperationException- if the- java.lang.ClassCastException- if the class of the specified element prevents it from being added to this list.- java.lang.NullPointerException- if the specified element is null and this list does not support null elements.- java.lang.IllegalArgumentException- if some aspect of the specified element prevents it from being added to this list.- java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index > size()).
 
 - 
removepublic E remove(int index) Removes the element at the specified position in this list (optional operation). Shifts any subsequent elements to the left (subtracts one from their indices). Returns the element that was removed from the list.- Specified by:
- removein interface- java.util.List<E>
- Parameters:
- index- the index of the element to removed.
- Returns:
- the element previously at the specified position.
- Throws:
- java.lang.UnsupportedOperationException- if the- java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index >= size()).
 
 - 
indexOfpublic int indexOf(java.lang.Object o) Returns the index in this list of the first occurrence of the specified element, or -1 if this list does not contain this element. More formally, returns the lowest index- Specified by:
- indexOfin interface- java.util.List<E>
- Parameters:
- o- element to search for.
- Returns:
- the index in this list of the first occurrence of the specified element, or -1 if this list does not contain this element.
- Throws:
- java.lang.ClassCastException- if the type of the specified element is incompatible with this list (optional).
- java.lang.NullPointerException- if the specified element is null.
 - 
lastIndexOfpublic int lastIndexOf(java.lang.Object o) Returns the index in this list of the last occurrence of the specified element, or -1 if this list does not contain this element. More formally, returns the highest index- Specified by:
- lastIndexOfin interface- java.util.List<E>
- Parameters:
- o- element to search for.
- Returns:
- the index in this list of the last occurrence of the specified element, or -1 if this list does not contain this element.
- Throws:
- java.lang.ClassCastException- if the type of the specified element is incompatible with this list (optional).
- java.lang.NullPointerException- if the specified element is null.
 - 
listIteratorpublic java.util.ListIterator<E> listIterator() Returns a list iterator of the elements in this list (in proper sequence).- Specified by:
- listIteratorin interface- java.util.List<E>
- Returns:
- a list iterator of the elements in this list (in proper sequence).
 
 - 
listIteratorpublic java.util.ListIterator<E> listIterator(int index) Returns a list iterator of the elements in this list (in proper sequence), starting at the specified position in this list. The specified index indicates the first element that would be returned by an initial call to the- Specified by:
- listIteratorin interface- java.util.List<E>
- Parameters:
- index- index of first element to be returned from the list iterator (by a call to the
- Returns:
- a list iterator of the elements in this list (in proper sequence), starting at the specified position in this list.
- Throws:
- java.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index > size()).
 - 
subListpublic java.util.List<E> subList(int fromIndex, int toIndex) Returns a view of the portion of this list between the specified- Specified by:
- subListin interface- java.util.List<E>
- Parameters:
- fromIndex- low endpoint (inclusive) of the subList.
- toIndex- high endpoint (exclusive) of the subList.
- Returns:
- a view of the specified range within this list.
- Throws:
- java.lang.IndexOutOfBoundsException- for an illegal endpoint index value (fromIndex < 0 || toIndex > size || fromIndex > toIndex).
 - 
toStringpublic java.lang.String toString() Get the string representation.- Overrides:
- toStringin class- java.lang.Object
 
 - 
writeReplaceprotected java.lang.Object writeReplace() throws java.io.ObjectStreamExceptionPerform special handling on serialization.- Throws:
- java.io.ObjectStreamException
 
 - 
readResolveprotected java.lang.Object readResolve() throws java.io.ObjectStreamExceptionPerform special handling on deserialization.- Throws:
- java.io.ObjectStreamException
 
 - 
mainpublic static void main(java.lang.String[] args) Main method for testing.
 - 
createTestvaluesprotected static java.lang.String[] createTestvalues(java.lang.String teststring, int size)Create some string values for testing.
 - 
checkForEmptySlotsprotected static void checkForEmptySlots(java.util.List list) Check for empty slots in list.
 
 
 
 
 
 
 
 
 
 
 
 
 
- 
 
-