|
JavaTM 2 Platform Standard Ed. 5.0 |
|||||||||
上一个类 下一个类 | 框架 无框架 | |||||||||
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |
java.lang.Object java.util.AbstractCollection<E>
public abstract class AbstractCollection<E>
此类提供了 Collection 接口的骨干实现,从而最大限度地减少了实现此接口所需的工作。
要实现一个不可修改的 collection,程序员只需扩展此类,并提供 iterator 和 size 方法的实现。(iterator 方法返回的迭代器必须实现 hasNext 和 next。)
要实现可修改的 collection,程序员还必须另外重写此类的 add 方法(否则,会抛出 UnsupportedOperationException),并且 iterator 方法返回的迭代器必须另外实现其 remove 方法。
按照 Collection 接口规范中的推荐,程序员通常应该提供一个 void (无参数)和 Collection 构造方法。
此类中每个非抽象方法的文档详细描述了其实现。如果要实现的 collection 允许更有效的实现,则可以重写这些方法中的每个方法。
此类是 Java Collections Framework 的成员。
Collection
构造方法摘要 | |
---|---|
protected |
AbstractCollection()
单独的构造方法。 |
方法摘要 | ||
---|---|---|
boolean |
add(E o)
确保此 collection 包含指定的元素(可选操作)。 |
|
boolean |
addAll(Collection<? extends E> c)
将指定 collection 中的所有元素添加到此 collection 中(可选操作)。 |
|
void |
clear()
从此 collection 中移除所有元素(可选操作)。 |
|
boolean |
contains(Object o)
如果此 collection 包含指定的元素,则返回 true。 |
|
boolean |
containsAll(Collection<?> c)
如果此 collection 包含指定 collection 中的所有元素,则返回 true。 |
|
boolean |
isEmpty()
如果此 collection 不包含元素,则返回 true。 |
|
abstract Iterator<E> |
iterator()
返回在此 collection 中的元素上进行迭代的迭代器。 |
|
boolean |
remove(Object o)
从此 collection 中移除指定元素的单个实例(如果存在)(可选操作)。 |
|
boolean |
removeAll(Collection<?> c)
从此 collection 中移除包含在指定 collection 中的所有元素(可选操作)。 |
|
boolean |
retainAll(Collection<?> c)
仅在此 collection 中保留指定 collection 中所包含的元素(可选操作)。 |
|
abstract int |
size()
返回此 collection 中的元素数。 |
|
Object[] |
toArray()
返回包含此 collection 中所有元素的数组。 |
|
|
toArray(T[] a)
返回包含此 collection 中所有元素的数组;返回数组的运行时类型是指定数组的类型。 |
|
String |
toString()
返回此 collection 的字符串表示形式。 |
从类 java.lang.Object 继承的方法 |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
从接口 java.util.Collection 继承的方法 |
---|
equals, hashCode |
构造方法详细信息 |
---|
protected AbstractCollection()
方法详细信息 |
---|
public abstract Iterator<E> iterator()
Iterable<E>
中的 iterator
Collection<E>
中的 iterator
public abstract int size()
Collection<E>
中的 size
public boolean isEmpty()
此实现返回 size() == 0。
Collection<E>
中的 isEmpty
public boolean contains(Object o)
此实现迭代该 collection 中的元素,并依次检查每个元素以确定其是否与指定的元素相等。
Collection<E>
中的 contains
o
- 要检查的对象,以确定其是否包含在此 collection 中。
public Object[] toArray()
此实现会分配返回的数组,并迭代 collection 中的元素,将每个对象引用存储在数组的下一个连续元素中,并从元素 0 开始。
Collection<E>
中的 toArray
public <T> T[] toArray(T[] a)
如果指定的数组能容纳 collection,并且有剩余的空间(即数组的元素比 collection 多),那么会将紧挨着 collection 尾部的元素设置为 null(这对确定 collection 的长度很有用,但只有 在调用方知道 collection 不包含任何 null 元素时才可行)。
如果此 collection 保证其迭代器按顺序返回其元素,那么此方法也必须按相同的顺序返回这些元素。
此实现会检查该数组是否足够大,以包含该 collection 中的元素;如果不能包含,则将分配一个具有适当大小和类型的新数组(使用反射)。然后,在该 collection 上进行迭代,将每个对象引用存储在数组的下一个连续元素中,并从元素 0 开始。如果该数组比该 collection 大,则在该 collection 尾部后面的第一个位置存储 null。
Collection<E>
中的 toArray
a
- 存储此 collection 的元素的数组(如果其足够大);否则,将为此分配一个具有相同运行时类型的新数组。
NullPointerException
- 如果指定的数组为 null。
ArrayStoreException
- 如果指定数组的运行时类型不是此 collection 中每个元素的运行时类型的超类型。public boolean add(E o)
此实现始终抛出 UnsupportedOperationException。
Collection<E>
中的 add
o
- 确保存在于此 collection 中的元素。
UnsupportedOperationException
- 如果此 collection 不支持 add 方法。
NullPointerException
- 如果此 collection 不允许 null 元素,并且指定的元素为 null。
ClassCastException
- 如果指定元素的类不允许该元素添加到此 collection 中。
IllegalArgumentException
- 如果此元素的某方面不允许它添加到此 collection 中。public boolean remove(Object o)
此实现在该 collection 上进行迭代,查找指定的元素。如果找到该元素,那么它会使用迭代器的 remove 方法从该 collection 中移除该元素。
注意,如果此 collection 的 iterator 方法所返回的迭代器无法实现 remove 方法,并且此 collection 包含指定的对象,那么此实现会抛出 UnsupportedOperationException。
Collection<E>
中的 remove
o
- 要从此 collection 中移除的元素(如果存在)。
UnsupportedOperationException
- 如果此 collection 不支持 remove 方法。public boolean containsAll(Collection<?> c)
此实现在指定的 collection 上进行迭代,依次检查该迭代器返回的每个元素,查看其是否包含在此 collection 中。如果包含所有元素,则返回 true;否则将返回 false。
Collection<E>
中的 containsAll
c
- 将检查其是否包含在此 collection 中的 collection。
NullPointerException
- 如果指定的 collection 为 null。contains(Object)
public boolean addAll(Collection<? extends E> c)
此实现在指定的 collection 上进行迭代,并依次将迭代器返回的每个对象添加到此 collection 中。
注意,除非重写 add,否则此实现将抛出 UnsupportedOperationException(假定指定的 collection 非空)。
Collection<E>
中的 addAll
c
- 将其元素添加到此 collection 的 collection。
UnsupportedOperationException
- 如果此 collection 不支持 addAll 方法。
NullPointerException
- 如果指定的 collection 为 null。add(Object)
public boolean removeAll(Collection<?> c)
此实现在此 collection 上进行迭代,依次检查该迭代器返回的每个元素,以查看其是否包含在指定的 collection 中。如果是,则使用迭代器的 remove 方法将其从此 collection 中移除。
注意,如果 iterator 方法返回的迭代器无法实现 remove 方法,并且此 collection 包含一个或多个与指定 collection 共有的元素,那么此实现将抛出 UnsupportedOperationException。
Collection<E>
中的 removeAll
c
- 要从此 collection 移除的元素。
UnsupportedOperationException
- 如果此 collection 不支持 removeAll 方法。
NullPointerException
- 如果指定的 collection 为 null。remove(Object)
,
contains(Object)
public boolean retainAll(Collection<?> c)
此实现在此 collection 上进行迭代,依次检查该迭代器返回的每个元素,以查看其是否包含在指定的 collection 中。如果不是,则使用迭代器的 remove 方法将其从此 collection 中移除。
注意,如果 iterator 方法返回的迭代器无法实现 remove 方法,并且此 collection 包含一个或多个在指定 collection 中不存在的元素,那么此实现将抛出 UnsupportedOperationException。
Collection<E>
中的 retainAll
c
- 将保留在此 collection 的元素。
UnsupportedOperationException
- 如果此 collection 不支持 retainAll 方法。
NullPointerException
- 如果指定的 collection 为 null。remove(Object)
,
contains(Object)
public void clear()
此实现在此 collection 上进行迭代,并使用 Iterator.remove 操作移除每个元素。为了提高效率,多数实现可能会选择重写此方法。
注意,如果此 collection 的 iterator 方法所返回的迭代器无法实现 remove 方法,并且此 collection 非空,那么此实现将抛出 UnsupportedOperationException。
Collection<E>
中的 clear
UnsupportedOperationException
- 如果此 collection 不支持 clear 方法。public String toString()
此实现会创建一个空字符串缓冲区,追加一个左方括号,然后在 collection 上进行迭代,依次追加每个元素的字符串表示形式。每追加一个元素后(最后一个元素除外),将追加字符串 ", "。最后,追加一个右括号。从字符串缓冲区获取一个字符串并返回它。
Object
中的 toString
|
JavaTM 2 Platform Standard Ed. 5.0 |
|||||||||
上一个类 下一个类 | 框架 无框架 | |||||||||
摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 |
版权所有 2004 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策。