黑马程序员技术交流社区
标题:
再论集合框架
[打印本页]
作者:
马云
时间:
2012-3-21 13:27
标题:
再论集合框架
学习框架最主要的是它的结构了吧(还有编程思想,那个态深了,我现在小菜bird的身份还没资格谈那个呢),那JAVA的集合框架也是如此,
首先明确三点,干什么用的,为了什么,怎么用。
我们围绕这个来仔细的把它的框架结构来组织一下,以便在加深理解,
(框架可不是学会用就可以了,在以后发展到高层次的时候会有很多的类似于框架的设计模式,它能在项目中为我们理顺清楚的思路,节省开发时间,可以提高高级别的扩展性。
做为JAVA开发组自己的框架,我们非常有必要了解一下他们的设计结构和思想:
先来个结构图(我们最常用的)
先以我们能理解的方式画啊,不专业啊,(正在学uml等后来再给大家补上正规的图啊)
collection<interface>(iterator)
|-------------List<interface>(
ListIterator
)
|------- ArrayList<class>
|------- LinkedList<class>
|------- Vector<class>
|-------------Set<interface>
|------- HashSet<class>
|------- TreeSet<class>
|-------------Map<interface>
|------- HashTable<class>
|------- HashMap<class>
|------- TreeMap<class>
集合什么时候用,用时要选择那个子类去实现。
集合的作用,当我们要对一组对象,或都数据进行统一的操作时,为了减少代码量的编写和实现逻辑的统一,这时我们就要以采用集合对象了,(还有其他的一些他家组织组织续上啊),
选用子类对象,
首选把下边的子类对象分为三大类:
list:元素是有序的,元素可以重复,因为该集合体系有索引
set:元素是无序的(存入和取出的顺序不一定一致),不可以重复
map:该集合存储键值对,一对一往里存,而且要保证键的唯一性。
当明确了这三个要求后就可以把范围转到这三个接口的其中一个了,接下来我们再来看三个接口下的子类:
List:
ArrayList:底层的数据结构使用的是数组结构(查询快,增删慢,不同步)
linkedList:底层使用的是链表结构(增删快,查询慢)
vector:底层是数组数据结构(和ArrayList功能一样,是同步的)(使用时注意他有一个elements()返回个Enumeration对象此对象可以像iterator那样迭代输出元素)
Set:
HashSet:底层数据结构是哈希表(HashCode())线程非同步的
HashSet是如何保证元素唯一性,是通过元素的HashCode值相同,才会判断equals是否为true,如果元素的 hashcode值不同,不会调用equals()
TreeSet
可以对Set集合中的元素进行排序
底层数据结构是二叉树,保证元素唯一性的依据:compareTo方法Comparable类
TreeSet排序的第一种方式,让元素自身具备比较性元素需要实现Comparable接口,覆盖compareTo方法
第二种方式:当元素自身不具备比较性时,或者具备的比较性不是所需要的这时就需要让集合自身具备比较性。在集合初始化时,就有了比较方式,
定义比较器,传给集合对象的构造器Comparator-->compare()
待续 上班ing……
Map
该集合存储键值对,一对一往里存,而且要保证键的唯一性。
|----Hashtable
底层是哈希表数据结构,不可以存入null键null值,(该集合是线程同步的-效率低)
|----HashMap
底层是哈希表数据结构,可以允许使用null键null值(该集合是不同步的-效率高)
|----TreeMap
底层是二叉树数据结构,线程不同步,可以用于给map集合中的键进行排序(排序)
根把每个子类的特性和自己的需求去实现子类,
set和list的对比:
set检索元素效率低下,删除和插入效率高,插入和删除不会引起元素位置改变,无序所存对角唯一,不可以重复存放,
list和数组类似,list可以动态增长,查找元素效率高,插入删除元素效率低,因为会引起其他元素位置改变,有序可以重复存放。
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2