代码改变世界

java 集合

2012-01-10 19:17  Rainbow  阅读(959)  评论(0编辑  收藏  举报

在java中,集合相关的内容多放在 java.util 包里面。java的集合主要有Collection接口和Map接口,同时还有Iterator 这个接口是实现foreach(for T in C)的遍历集合元素的操作。

image

  • Collection 接口类方法:

方法名 描述
add(Object o) 像集合中加入一个对象的引用
void clear() 清空集合中所有对象的引用
contains(Object o) 判读集合中是否存在特定对象的引用
Iterator iterator 返回一个Iterator对象,使用foreach遍历
remove(Object o) 从集合中删除特定对象的引用
size() 返回集合的元素数目
Object[] toArray() 返回一个数组
isEmpty() 判读集合是否为空

以上是collection接口的共有方法,特定的子类还包含自己特有的有些方法。如 addAll(),first(),indexOf(),get()等等。

  • Iterator 接口的方法

方法 描述
hasNext() 判断是否已经到底
next() 返回下一个元素
remove 从集合中删除由上一个next()返回的对象

 

  • 集合类方面的异同:

image

① 如果涉及到堆栈,队列等操作,应该考虑用List。如果要进行大量的随机访问,应使用ArrayList;如果经常进行插入与删除操作,用使用LinkedList。

② HashMap设计用来快速访问;而TreeMap保持“键”始终处于排序状态,所以没有HashMap快。LinkedHashMap保持元素插入的顺序,但是也通过散列提供了快速访问能力。

③ Set不接受重复元素。HashSet提供最快的查询速度,而TreeSet保持元素处于排序状态。LinkedHashSet以插入顺序保存元素。

④ 对哈希表的操作,作为key的对象要正确重写equals和hashCode方法。

⑤ 尽量返回接口而非实际的类型(针对抽象编程),如返回List而非ArrayList,这样如果以后需要将ArrayList换成LinkedList时,客户端代码不用改变。

⑥ 程序中不应该使用过时的Vector\Hashtable\Stack。

  • 常见的问题

collection和collections有啥区别?

collection是java中关于集合的接口。而collections是java.util中的类,它包含了对集合操作的静态方法。

HasMap和Hastable的区别?

都属于Map接口的类,实现了将惟一键映射到特定的值上。

HasMap类没有分类和排序。它允许一个null键和null值。

Hastable类似于HasMap但是不允许null键和null值。因此比Hasmap慢。

其实关于集合的内容还非常多。好比,排序,性能等方面。以后需要写一篇专门的文章。