|
LimeWire collection component api | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjava.util.AbstractCollection<E>
java.util.AbstractList<E>
org.limewire.collection.TreeList<E>
public class TreeList<E>
A List implementation that is optimized for fast insertions and
removals at any index in the list.
This list implementation utilizes a tree structure internally to ensure that
all insertions and removals are O(log n). This provides much faster performance
than both an ArrayList and a LinkedList where elements
are inserted and removed repeatedly from anywhere in the list.
The following relative performance statistics are indicative of this class:
get add insert iterate remove
TreeList 3 5 1 2 1
ArrayList 1 1 40 1 40
LinkedList 5800 1 350 2 325
ArrayList is a good general purpose list implementation.
It is faster than TreeList for most operations except inserting
and removing in the middle of the list. ArrayList also uses less
memory as TreeList uses one object per entry.
LinkedList is rarely a good choice of implementation.
TreeList is almost always a good replacement for it, although it
does use slightly more memory.
| Field Summary |
|---|
| Fields inherited from class java.util.AbstractList |
|---|
modCount |
| Constructor Summary | |
|---|---|
TreeList()
Constructs a new empty list. |
|
TreeList(java.util.Collection<? extends E> coll)
Constructs a new empty list that copies the specified list. |
|
| Method Summary | |
|---|---|
void |
add(int index,
E obj)
Adds a new element to the list. |
void |
clear()
Clears the list, removing all entries. |
boolean |
contains(java.lang.Object object)
Searches for the presence of an object in the list. |
E |
get(int index)
Gets the element at the specified index. |
int |
indexOf(java.lang.Object object)
Searches for the index of an object in the list. |
java.util.Iterator<E> |
iterator()
Gets an iterator over the list. |
java.util.ListIterator<E> |
listIterator()
Gets a ListIterator over the list. |
java.util.ListIterator<E> |
listIterator(int fromIndex)
Gets a ListIterator over the list. |
E |
remove(int index)
Removes the element at the specified index. |
boolean |
remove(java.lang.Object o)
Removes the object. |
E |
set(int index,
E obj)
Sets the element at the specified index. |
int |
size()
Gets the current size of the list. |
java.lang.Object[] |
toArray()
Converts the list into an array. |
| Methods inherited from class java.util.AbstractList |
|---|
add, addAll, equals, hashCode, lastIndexOf, removeRange, subList |
| Methods inherited from class java.util.AbstractCollection |
|---|
addAll, containsAll, isEmpty, removeAll, retainAll, toArray, toString |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Methods inherited from interface java.util.List |
|---|
addAll, containsAll, isEmpty, removeAll, retainAll, toArray |
| Constructor Detail |
|---|
public TreeList()
public TreeList(java.util.Collection<? extends E> coll)
coll - the collection to copy
java.lang.NullPointerException - if the collection is null| Method Detail |
|---|
public E get(int index)
get in interface java.util.List<E>get in class java.util.AbstractList<E>index - the index to retrieve
public int size()
size in interface java.util.Collection<E>size in interface java.util.List<E>size in class java.util.AbstractCollection<E>public java.util.Iterator<E> iterator()
iterator in interface java.lang.Iterable<E>iterator in interface java.util.Collection<E>iterator in interface java.util.List<E>iterator in class java.util.AbstractList<E>public java.util.ListIterator<E> listIterator()
listIterator in interface java.util.List<E>listIterator in class java.util.AbstractList<E>public java.util.ListIterator<E> listIterator(int fromIndex)
listIterator in interface java.util.List<E>listIterator in class java.util.AbstractList<E>fromIndex - the index to start from
public int indexOf(java.lang.Object object)
indexOf in interface java.util.List<E>indexOf in class java.util.AbstractList<E>public boolean contains(java.lang.Object object)
contains in interface java.util.Collection<E>contains in interface java.util.List<E>contains in class java.util.AbstractCollection<E>public java.lang.Object[] toArray()
toArray in interface java.util.Collection<E>toArray in interface java.util.List<E>toArray in class java.util.AbstractCollection<E>
public void add(int index,
E obj)
add in interface java.util.List<E>add in class java.util.AbstractList<E>index - the index to add beforeobj - the element to add
public E set(int index,
E obj)
set in interface java.util.List<E>set in class java.util.AbstractList<E>index - the index to setobj - the object to store at the specified index
java.lang.IndexOutOfBoundsException - if the index is invalidpublic boolean remove(java.lang.Object o)
remove in interface java.util.Collection<E>remove in interface java.util.List<E>remove in class java.util.AbstractCollection<E>public E remove(int index)
remove in interface java.util.List<E>remove in class java.util.AbstractList<E>index - the index to remove
public void clear()
clear in interface java.util.Collection<E>clear in interface java.util.List<E>clear in class java.util.AbstractList<E>
|
LimeWire collection component api | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||