java.util.concurrent
Class CopyOnWriteArrayList<E>
- Cloneable, Collection<E>, Iterable<E>, List<E>, RandomAccess, Serializable
 A thread-safe implementation of an ArrayList. A CopyOnWriteArrayList is
 as special ArrayList which performs copies of the underlying storage
 each time a write (
remove, 
add etc..) operation
 is performed.
 
 The update operation in this class run usually in 
O(n) or worse,
 but traversal operations are fast and efficient, especially when running in
 a multi-thread environment without the need to design complex synchronize
 mechanisms.
 
 
Iterators in this class work on a snapshot of the backing store
 at the moment the iterator itself was created, hence the iterator will not
 reflect changes in the underlying storage. Thus, update operation on the
 
Iterators are not supported, but as interferences from other
 threads are impossible, no 
ConcurrentModificationException
 will be ever thrown from within the 
Iterator.
 
 This class is especially useful when used with event handling, like the
 following code demonstrates:
 
 CopyOnWriteArrayList listeners =
   new CopyOnWriteArrayList();
 [...]
 for (final EventListener listener : listeners)
   {
     Runnable dispatcher = new Runnable() {
       public void run()
       {
         listener.preferenceChange(event);
       }
     };
     Executor executor = Executors.newSingleThreadExecutor();
     executor.execute(dispatcher);
   }
 
| CopyOnWriteArrayList() Construct a new ArrayList with the default capacity (16).
 |  | CopyOnWriteArrayList(E> c) Construct a new ArrayList, and initialize it with the elements in the
 supplied Collection. 
 |  | CopyOnWriteArrayList(E[] array) Construct a new ArrayList, and initialize it with the elements in the
 supplied array.
 |  
 
|   | T[] toArray(T[] a) Returns an Array whose component type is the runtime component type of the
 passed-in Array. 
 |  |  boolean | add(E e) Appends the supplied element to the end of this list. 
 |  |  void | add(int index, E e) Adds the supplied element at the specified index, shifting all elements
 currently at that index or higher one to the right. 
 |  |  boolean | addAll(E> c) Add each element in the supplied Collection to this List. 
 |  |  boolean | addAll(int index, E> c) Add all elements in the supplied collection, inserting them beginning at
 the specified index. c can contain objects of any type, as well as null
 values.
 |  |  int | addAllAbsent(E> c) Adds all the element from the given collection that are not already
 in this list.
 |  |  boolean | addIfAbsent(E val) Adds an element if the list does not contains it already.
 |  |  void | clear() Removes all elements from this List
 |  |  Object | clone() Creates a shallow copy of this ArrayList (elements are not cloned).
 |  |  boolean | contains(Object e) Returns true if element is in this ArrayList.
 |  |  boolean | containsAll(Collection> c) Tests whether this collection contains all the elements in a given
 collection. 
 |  |  boolean | equals(Object o) Test whether this list is equal to another object. 
 |  |  E | get(int index) Retrieves the element at the user-supplied index.
 |  |  int | hashCode() Obtains a hash code for this list. 
 |  |  int | indexOf(E e, int index) Return the lowest index greater equal indexat whicheappears in this List, or -1 if it does not
 appear.
 |  |  int | indexOf(Object e) Returns the lowest index at which element appears in this List, or -1 if it
 does not appear.
 |  |  boolean | isEmpty() Checks if the list is empty.
 |  |  Iterator | iterator() Return an Iterator containing the elements of this list.
 |  |  int | lastIndexOf(E e, int index) Returns the highest index lesser equal indexat
 whicheappears in this List, or -1 if it does not
 appear.
 |  |  int | lastIndexOf(Object e) Returns the highest index at which element appears in this List, or -1 if
 it does not appear.
 |  |  ListIterator | listIterator() Return a ListIterator containing the elements of this list.
 |  |  ListIterator | listIterator(int index) Return a ListIterator over the elements of this list starting at
 the specified index.  
 |  |  E | remove(int index) Removes the element at the user-supplied index.
 |  |  boolean | remove(Object element) Remove the first occurrence, if any, of the given object from this list,
 returning trueif the object was removed,falseotherwise.
 |  |  boolean | removeAll(Collection> c) Removes all the elements contained in the given collection.
 |  |  boolean | retainAll(Collection> c) Removes all the elements that are not in the passed collection.
 |  |  E | set(int index, E e) Sets the element at the specified index. 
 |  |  int | size() Returns the number of elements in this list.
 |  |  List | subList(int fromIndex, int toIndex) Obtain a List view of a subsection of this list, from fromIndex
 (inclusive) to toIndex (exclusive). 
 |  |  Object[] | toArray() Returns an Object array containing all of the elements in this ArrayList.
 |  |  String | toString() Convert this Object to a human-readable String.
 |  
 
| clone,equals,extends Object> getClass,finalize,hashCode,notify,notifyAll,toString,wait,wait,wait |  
 
CopyOnWriteArrayList
public CopyOnWriteArrayList()
 Construct a new ArrayList with the default capacity (16).
CopyOnWriteArrayList
public CopyOnWriteArrayList(E> c)
 Construct a new ArrayList, and initialize it with the elements in the
 supplied Collection. The initial capacity is 110% of the Collection's size.
- c- the collection whose elements will initialize this list
CopyOnWriteArrayList
public CopyOnWriteArrayList(E[] array)
 Construct a new ArrayList, and initialize it with the elements in the
 supplied array.
- array- the array used to initialize this list
T[] toArray
public  T[] toArray(T[] a)
 Returns an Array whose component type is the runtime component type of the
 passed-in Array. The returned Array is populated with all of the elements
 in this ArrayList. If the passed-in Array is not large enough to store all
 of the elements in this List, a new Array will be created and returned; if
 the passed-in Array is larger than the size of this List, then
 size() index will be set to null.
- T[] toArray in interface List<E>
- T[] toArray in interface Collection<E>
- an array representation of this list
add
public boolean add(E e)
 Appends the supplied element to the end of this list. The element, e, can
 be an object of any type or null.
- add in interface List<E>
- add in interface Collection<E>
- e- the element to be appended to this list
- true, the add will always succeed
add
public void add(int index,
                E e) Adds the supplied element at the specified index, shifting all elements
 currently at that index or higher one to the right. The element, e, can be
 an object of any type or null.
- add in interface List<E>
- index- the index at which the element is being added
- e- the item being added
addAll
public boolean addAll(E> c)
 Add each element in the supplied Collection to this List. It is undefined
 what happens if you modify the list while this is taking place; for
 example, if the collection contains this list. c can contain objects of any
 type, as well as null values.
- addAll in interface List<E>
- addAll in interface Collection<E>
- c- a Collection containing elements to be added to this List
- true if the list was modified, in other words c is not empty
addAll
public boolean addAll(int index,
                      E> c) Add all elements in the supplied collection, inserting them beginning at
 the specified index. c can contain objects of any type, as well as null
 values.
- addAll in interface List<E>
- index- the index at which the elements will be inserted
- c- the Collection containing the elements to be inserted
addAllAbsent
public int addAllAbsent(E> c)
 Adds all the element from the given collection that are not already
 in this list.
- c- the Collection containing the elements to be inserted
- true the list internal storage changed as a result of this
operation, false otherwise.
addIfAbsent
public boolean addIfAbsent(E val)
 Adds an element if the list does not contains it already.
- val- the element to add to the list.
- true if the element was added, false otherwise.
clone
public Object clone()
 Creates a shallow copy of this ArrayList (elements are not cloned).
- clone in interface Object
containsAll
public boolean containsAll(Collection> c)
 Tests whether this collection contains all the elements in a given
 collection. This implementation iterates over the given collection,
 testing whether each element is contained in this collection. If any one
 is not, false is returned. Otherwise true is returned.
- containsAll in interface List<E>
- containsAll in interface Collection<E>
- c- the collection to test against
- true if this collection contains all the elements in the given
collection
equals
public boolean equals(Object o)
 Test whether this list is equal to another object. A List is defined to be
 equal to an object if and only if that object is also a List, and the two
 lists have the same sequence. Two lists l1 and l2 are equal if and only
 if l1.size() == l2.size(), and for every integer n between 0
 and l1.size() - 1 inclusive, l1.get(n) == null ?
 l2.get(n) == null : l1.get(n).equals(l2.get(n)).
- equals in interface List<E>
- equals in interface Collection<E>
- equals in interface Object
- o- the object to test for equality with this list
- true if o is equal to this list
get
public E get(int index)
 Retrieves the element at the user-supplied index.
- get in interface List<E>
- index- the index of the element we are fetching
hashCode
public int hashCode()
 Obtains a hash code for this list. In order to obey the general
 contract of the hashCode method of class Object, this value is
 calculated as follows:
hashCode = 1;
Iterator i = list.iterator();
while (i.hasNext())
{
Object obj = i.next();
hashCode = 31 * hashCode + (obj == null ? 0 : obj.hashCode());
}
 This ensures that the general contract of Object.hashCode()
 is adhered to.
- hashCode in interface List<E>
- hashCode in interface Collection<E>
- hashCode in interface Object
- the hash code of this list
indexOf
public int indexOf(E e,
                   int index) Return the lowest index greater equal index at which
 e appears in this List, or -1 if it does not
 appear.
- e- the element whose inclusion in the list is being tested
- index- the index at which the search begins
- the index where ewas found
indexOf
public int indexOf(Object e)
 Returns the lowest index at which element appears in this List, or -1 if it
 does not appear.
- indexOf in interface List<E>
- e- the element whose inclusion in the List is being tested
- the index where e was found
iterator
public Iterator iterator()
 Return an Iterator containing the elements of this list.
 The Iterator uses a snapshot of the state of the internal storage
 at the moment this method is called and does not support
 update operations, so no synchronization is needed to traverse the
 iterator.
- iterator in interface List<E>
- iterator in interface Collection<E>
- iterator in interface Iterable<E>
- an Iterator containing the elements of this list in sequence.
lastIndexOf
public int lastIndexOf(E e,
                       int index) Returns the highest index lesser equal index at
 which e appears in this List, or -1 if it does not
 appear.
- e- the element whose inclusion in the list is being tested
- index- the index at which the search begins
- the index where ewas found
lastIndexOf
public int lastIndexOf(Object e)
 Returns the highest index at which element appears in this List, or -1 if
 it does not appear.
- lastIndexOf in interface List<E>
- e- the element whose inclusion in the List is being tested
- the index where e was found
listIterator
public ListIterator listIterator()
 Return a ListIterator containing the elements of this list.
 The Iterator uses a snapshot of the state of the internal storage
 at the moment this method is called and does not support
 update operations, so no synchronization is needed to traverse the
 iterator.
- listIterator in interface List<E>
- a ListIterator containing the elements of this list in sequence.
listIterator
public ListIterator listIterator(int index)
 Return a ListIterator over the elements of this list starting at
 the specified index.  An initial call to next() will thus
 return the element at index, while an initial call to
previous() will return the element at index-1.  The
 Iterator uses a snapshot of the state of the internal storage
 at the moment this method is called and does not support
 update operations, so no synchronization is needed to traverse the
 iterator.
- listIterator in interface List<E>
- index- the index at which to start iterating.
- a ListIterator containing the elements of this list in sequence.
remove
public E remove(int index)
 Removes the element at the user-supplied index.
- remove in interface List<E>
- index- the index of the element to be removed
remove
public boolean remove(Object element)
 Remove the first occurrence, if any, of the given object from this list,
 returning true if the object was removed, false
 otherwise.
- remove in interface List<E>
- remove in interface Collection<E>
- element- the object to be removed.
- true if element was removed, false otherwise. false means also that
the underlying storage was unchanged after this operation concluded.
removeAll
public boolean removeAll(Collection> c)
 Removes all the elements contained in the given collection.
 This method removes the elements that are contained in both
 this list and in the given collection.
- removeAll in interface List<E>
- removeAll in interface Collection<E>
- c- the collection containing the elements to be removed from this
list.
- true if at least one element was removed, indicating that
the list internal storage changed as a result, false otherwise.
retainAll
public boolean retainAll(Collection> c)
 Removes all the elements that are not in the passed collection.
 If the collection is void, this method has the same effect of
 clear().
 Please, note that this method is extremely slow (unless the argument has
 size == 0) and has bad performance is both space and time
 usage.
- retainAll in interface List<E>
- retainAll in interface Collection<E>
- c- the collection containing the elements to be retained by this
list.
- true the list internal storage changed as a result of this
operation, false otherwise.
set
public E set(int index,
             E e) Sets the element at the specified index. The new element, e, can be an
 object of any type or null.
- set in interface List<E>
- index- the index at which the element is being set
- e- the element to be set
- the element previously at the specified index
subList
public List subList(int fromIndex,
                       int toIndex)
 Obtain a List view of a subsection of this list, from fromIndex
 (inclusive) to toIndex (exclusive). If the two indices are equal, the
 sublist is empty. The returned list should be modifiable if and only
 if this list is modifiable. Changes to the returned list should be
 reflected in this list. If this list is structurally modified in
 any way other than through the returned list, the result of any subsequent
 operations on the returned list is undefined.
 
 This implementation returns a subclass of AbstractList. It stores, in
 private fields, the offset and size of the sublist, and the expected
 modCount of the backing list. If the backing list implements RandomAccess,
 the sublist will also.
 
 The subclass's 
set(int, Object), 
get(int),
 
add(int, Object), 
remove(int),
 
addAll(int, Collection) and
 
removeRange(int, int) methods all delegate to the
 corresponding methods on the backing abstract list, after
 bounds-checking the index and adjusting for the offset. The
 
addAll(Collection c) method merely returns addAll(size, c).
 The 
listIterator(int) method returns a "wrapper object"
 over a list iterator on the backing list, which is created with the
 corresponding method on the backing list. The 
iterator()
 method merely returns listIterator(), and the 
size() method
 merely returns the subclass's size field.
 
 All methods first check to see if the actual modCount of the backing
 list is equal to its expected value, and throw a
 ConcurrentModificationException if it is not.
- subList in interface List<E>
- fromIndex- the index that the returned list should start from
(inclusive)
- toIndex- the index that the returned list should go to (exclusive)
- a List backed by a subsection of this list
toArray
public Object[] toArray()
 Returns an Object array containing all of the elements in this ArrayList.
 The array is independent of this list.
- toArray in interface List<E>
- toArray in interface Collection<E>
- an array representation of this list
toString
public String toString()
 Convert this Object to a human-readable String.
 There are no limits placed on how long this String
 should be or what it should contain.  We suggest you
 make it as intuitive as possible to be able to place
 it into 
System.out.println()
 and such.
 
It is typical, but not required, to ensure that this method
 never completes abruptly with a 
RuntimeException.
 
This method will be called when performing string
 concatenation with this object.  If the result is
 
null, string concatenation will instead
 use 
"null".
 
The default implementation returns
 
getClass().getName() + "@" +
      Integer.toHexString(hashCode()).
- toString in interface Object
- the String representing this Object, which may be null
CopyOnWriteArrayList.java
   Copyright (C) 2006 Free Software Foundation
This file is part of GNU Classpath.
GNU Classpath is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
GNU Classpath is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Classpath; see the file COPYING.  If not, write to the
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 USA.
Linking this library statically or dynamically with other modules is
making a combined work based on this library.  Thus, the terms and
conditions of the GNU General Public License cover the whole
combination.
As a special exception, the copyright holders of this library give you
permission to link this library with independent modules to produce an
executable, regardless of the license terms of these independent
modules, and to copy and distribute the resulting executable under
terms of your choice, provided that you also meet, for each linked
independent module, the terms and conditions of the license of that
module.  An independent module is a module which is not derived from
or based on this library.  If you modify this library, you may extend
this exception to your version of the library, but you are not
obligated to do so.  If you do not wish to do so, delete this
exception statement from your version.