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 Summary
Fields 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 Summary
Constructors Constructor Description WeakList()Create a new list.
-
Method Summary
All 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
-
array
protected transient java.lang.ref.Reference<E>[] array
The list of elements.
-
size
protected int size
The number of elements.
-
state
protected int state
The state (to check for modifications).
-
queue
protected transient java.lang.ref.ReferenceQueue queue
Reference queue for garbage-collected elements.
-
serialized_list
protected java.util.List<E> serialized_list
-
-
Method Detail
-
size
public int size()
Returns the number of elements in this list. If this list contains more than- Specified by:
sizein interfacejava.util.Collection<E>- Specified by:
sizein interfacejava.util.List<E>- Returns:
- the number of elements in this list.
-
isEmpty
public boolean isEmpty()
Returns- Specified by:
isEmptyin interfacejava.util.Collection<E>- Specified by:
isEmptyin interfacejava.util.List<E>- Returns:
-
contains
public boolean contains(java.lang.Object o)
Returns- Specified by:
containsin interfacejava.util.Collection<E>- Specified by:
containsin interfacejava.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.
-
iterator
public 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.
-
toArray
public 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 interfacejava.util.Collection<E>- Specified by:
toArrayin interfacejava.util.List<E>- Returns:
- an array containing all of the elements in this list in proper sequence.
- See Also:
Arrays.asList(Object[])
-
toArray
public 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 interfacejava.util.Collection<E>- Specified by:
toArrayin interfacejava.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
-
add
public boolean add(E o)
Appends the specified element to the end of this list (optional operation).- Specified by:
addin interfacejava.util.Collection<E>- Specified by:
addin interfacejava.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.
-
remove
public 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 interfacejava.util.Collection<E>- Specified by:
removein interfacejava.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
-
containsAll
public boolean containsAll(java.util.Collection c)
Returns- Specified by:
containsAllin interfacejava.util.Collection<E>- Specified by:
containsAllin interfacejava.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)
-
addAll
public 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 interfacejava.util.Collection<E>- Specified by:
addAllin interfacejava.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)
-
addAll
public 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 interfacejava.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()).
-
removeAll
public 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 interfacejava.util.Collection<E>- Specified by:
removeAllin interfacejava.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)
-
retainAll
public 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 interfacejava.util.Collection<E>- Specified by:
retainAllin interfacejava.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)
-
clear
public 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).
-
get
public E get(int index)
Returns the element at the specified position in this list.- Specified by:
getin interfacejava.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()).
-
set
public 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 interfacejava.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 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 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()).
-
add
public 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 interfacejava.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 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 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()).
-
remove
public 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 interfacejava.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 thejava.lang.IndexOutOfBoundsException- if the index is out of range (index < 0 || index >= size()).
-
indexOf
public 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 interfacejava.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.
-
lastIndexOf
public 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 interfacejava.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.
-
listIterator
public java.util.ListIterator<E> listIterator()
Returns a list iterator of the elements in this list (in proper sequence).- Specified by:
listIteratorin interfacejava.util.List<E>- Returns:
- a list iterator of the elements in this list (in proper sequence).
-
listIterator
public 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 interfacejava.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()).
-
subList
public java.util.List<E> subList(int fromIndex, int toIndex)
Returns a view of the portion of this list between the specified- Specified by:
subListin interfacejava.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).
-
toString
public java.lang.String toString()
Get the string representation.- Overrides:
toStringin classjava.lang.Object
-
writeReplace
protected java.lang.Object writeReplace() throws java.io.ObjectStreamExceptionPerform special handling on serialization.- Throws:
java.io.ObjectStreamException
-
readResolve
protected java.lang.Object readResolve() throws java.io.ObjectStreamExceptionPerform special handling on deserialization.- Throws:
java.io.ObjectStreamException
-
main
public static void main(java.lang.String[] args)
Main method for testing.
-
createTestvalues
protected static java.lang.String[] createTestvalues(java.lang.String teststring, int size)Create some string values for testing.
-
checkForEmptySlots
protected static void checkForEmptySlots(java.util.List list)
Check for empty slots in list.
-
-