java.lang.Object | |||
↳ | java.util.AbstractCollection<E> | ||
↳ | java.util.AbstractSet<E> | ||
↳ | java.util.concurrent.CopyOnWriteArraySet<E> |
A Set that uses CopyOnWriteArrayList for all of its operations. Thus, it shares the same basic properties:
Sample Usage. Probably the main application of copy-on-write sets are classes that maintain sets of Handler objects that must be multicasted to upon an update command. This is a classic case where you do not want to be holding a lock while sending a message, and where traversals normally vastly overwhelm additions.
class Handler { void handle(); ... } class X { private final CopyOnWriteArraySet<Handler> handlers = new CopyOnWriteArraySet<Handler>(); public void addHandler(Handler h) { handlers.add(h); } private long internalState; private synchronized void changeState() { internalState = ...; } public void update() { changeState(); Iterator it = handlers.iterator(); while (it.hasNext()) it.next().handle(); } }
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Creates an empty set.
| |||||||||||
Creates a set containing all of the elements of the specified
Collection.
|
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Attempts to add
object to the contents of this
Collection (optional). | |||||||||||
Attempts to add all of the objects contained in
collection
to the contents of this Collection (optional). | |||||||||||
Removes all elements from this
Collection , leaving it empty (optional). | |||||||||||
Tests whether this
Collection contains the specified object. | |||||||||||
Tests whether this
Collection contains all objects contained in the
specified Collection . | |||||||||||
Returns if this
Collection contains no elements. | |||||||||||
Returns an instance of Iterator that may be used to access the
objects contained by this
Collection . | |||||||||||
Removes one instance of the specified object from this
Collection if one
is contained (optional). | |||||||||||
Removes all occurrences in this collection which are contained in the
specified collection.
| |||||||||||
Removes all objects from this
Collection that are not also found in the
Collection passed (optional). | |||||||||||
Returns a count of how many objects this
Collection contains. | |||||||||||
Returns an array containing all elements contained in this
Collection . | |||||||||||
Returns a new array containing all elements contained in this
Collection . |
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class java.util.AbstractSet
| |||||||||||
From class java.util.AbstractCollection
| |||||||||||
From class java.lang.Object
| |||||||||||
From interface java.lang.Iterable
| |||||||||||
From interface java.util.Collection
| |||||||||||
From interface java.util.Set
|
Creates a set containing all of the elements of the specified Collection.
c | the collection |
---|
Attempts to add object
to the contents of this
Collection
(optional).
After this method finishes successfully it is guaranteed that the object
is contained in the collection.
If the collection was modified it returns true
, false
if
no changes were made.
An implementation of Collection
may narrow the set of accepted
objects, but it has to specify this in the documentation. If the object
to be added does not meet this restriction, then an
IllegalArgumentException
is thrown.
If a collection does not yet contain an object that is to be added and
adding the object fails, this method must throw an appropriate
unchecked Exception. Returning false is not permitted in this case
because it would violate the postcondition that the element will be part
of the collection after this method finishes.
o | the object to add. |
---|
true
if this Collection
is
modified, false
otherwise.Attempts to add all of the objects contained in collection
to the contents of this Collection
(optional). This implementation
iterates over the given Collection
and calls add
for each
element. If any of these calls return true
, then true
is
returned as result of this method call, false
otherwise. If this
Collection
does not support adding elements, an UnsupportedOperationException
is thrown.
If the passed Collection
is changed during the process of adding elements
to this Collection
, the behavior depends on the behavior of the passed
Collection
.
c | the collection of objects. |
---|
true
if this Collection
is modified, false
otherwise.Removes all elements from this Collection
, leaving it empty (optional).
This implementation iterates over this Collection
and calls the remove
method on each element. If the iterator does not support removal
of elements, an UnsupportedOperationException
is thrown.
Concrete implementations usually can clear a Collection
more efficiently
and should therefore overwrite this method.
Tests whether this Collection
contains the specified object. This
implementation iterates over this Collection
and tests, whether any
element is equal to the given object. If object != null
then
object.equals(e)
is called for each element e
returned by
the iterator until the element is found. If object == null
then
each element e
returned by the iterator is compared with the test
e == null
.
o | the object to search for. |
---|
true
if object is an element of this Collection
, false
otherwise.Tests whether this Collection
contains all objects contained in the
specified Collection
. This implementation iterates over the specified
Collection
. If one element returned by the iterator is not contained in
this Collection
, then false
is returned; true
otherwise.
c | the collection of objects. |
---|
true
if all objects in the specified Collection
are
elements of this Collection
, false
otherwise.Returns if this Collection
contains no elements. This implementation
tests, whether size
returns 0.
true
if this Collection
has no elements, false
otherwise.Returns an instance of Iterator that may be used to access the
objects contained by this Collection
. The order in which the elements are
returned by the Iterator is not defined unless the instance of the
Collection
has a defined order. In that case, the elements are returned in that order.
In this class this method is declared abstract and has to be implemented
by concrete Collection
implementations.
Collection
contents.Removes one instance of the specified object from this Collection
if one
is contained (optional). This implementation iterates over this
Collection
and tests for each element e
returned by the iterator,
whether e
is equal to the given object. If object != null
then this test is performed using object.equals(e)
, otherwise
using object == null
. If an element equal to the given object is
found, then the remove
method is called on the iterator and
true
is returned, false
otherwise. If the iterator does
not support removing elements, an UnsupportedOperationException
is thrown.
o | the object to remove. |
---|
true
if this Collection
is modified, false
otherwise.Removes all occurrences in this collection which are contained in the specified collection.
c | the collection of objects to remove. |
---|
true
if this collection was modified, false
otherwise.Removes all objects from this Collection
that are not also found in the
Collection
passed (optional). After this method returns this Collection
will only contain elements that also can be found in the Collection
passed to this method.
This implementation iterates over this Collection
and tests for each
element e
returned by the iterator, whether it is contained in
the specified Collection
. If this test is negative, then the remove
method is called on the iterator. If the iterator does not
support removing elements, an UnsupportedOperationException
is
thrown.
c | the collection of objects to retain. |
---|
true
if this Collection
is modified, false
otherwise.Returns a count of how many objects this Collection
contains.
In this class this method is declared abstract and has to be implemented
by concrete Collection
implementations.
Collection
contains, or Integer.MAX_VALUE
if there are more than Integer.MAX_VALUE
elements in this
Collection
.Returns an array containing all elements contained in this Collection
. If
the specified array is large enough to hold the elements, the specified
array is used, otherwise an array of the same type is created. If the
specified array is used and is larger than this Collection
, the array
element following the Collection
elements is set to null.
If the implementation has ordered elements it will return the element
array in the same order as an iterator would return them.
toArray(new Object[0])
behaves exactly the same way as
toArray()
does.
a | the array. |
---|
Collection
.Returns a new array containing all elements contained in this Collection
.
If the implementation has ordered elements it will return the element
array in the same order as an iterator would return them.
The array returned does not reflect any changes of the Collection
. A new
array is created even if the underlying data structure is already an
array.
Collection
.