java容器类库

java容器类库一共有两种主要类型:CollectionMap

两者区别在于容器内每个“槽”所存储的元素个数不同。Collection类型中,每个“槽”只有一个元素:Map类型中,持有key-value关联像一个小型数据库。

Collection子类包括:List(将以特定次序存储元素,所以取出来的顺序可能和放入顺序不同)、Set(每个值只能保存1个对象,不能含有重复的元素)和Queue(先进先出的容器)。List子类包括:ArrayList(擅长随机访问元素,但在list中插入、删除、移动元素较慢)、LinkedList(与ArrayList相反,插入、删除、移动元素方便,随机访问元素差)和Vector类型;Set子类包括:HashSet(使用散列函数)、TreeSet(使用红黑树)和LinkedHashSet(使用链表结合散列函数)类型;Queue子类包括:PriorityQueue类型。

Map子类包括:HashMapHashTableTreeMap类型。

特征:

List、Set、Map将所有的对象一律视为Object类;

Collection、List、Set、Map都是接口,不能实例化。继承自它们的ArrayList、Vector、HashTable、HashMap、stack是具体class,可以被实例化。

③ Vector容器确切知道它所持有的对象隶属什么类别。Vector不进行边界检查。

 

如何选择容器类:

在各种List中,最好的做法是以ArrayList作为默认选择。当插入、删除、移动元素频繁时,使用LinkedList;Vector总是比ArrayList慢;在各种Set中,HashSet通常优于TreeSet(插入、查找)。只有当需要产生一个经过排序的序列时,才用TreeSet。TreeSet的意义时用来维护其内元素的排序状态;在各种Map中,HashMap用于快速查找。当元素个数固定时,最好使用Array,因为Array的效率时最高的。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值