网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  进阶:vector、arraylist和list的异同     
  文章作者:未知  文章来源:赛迪网技术社区  
  查看:50次  录入:管理员--2008-01-28  
 

线性表,链表,哈希表是常用的数据结构,在进行java开发时,jdk已经为我们提供了一系列相应的类来实现基本的数据结构。这些类均在java.util包中。本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类。

collection
├list
│├linkedlist
│├arraylist
│└vector
│ └stack
└set
map
├hashtable
├hashmap
└weakhashmap

collection接口
  collection是最基本的集合接口,一个collection代表一组object,即collection的元素(elements)。一些collection允许相同的元素而另一些不行。一些能排序而另一些不行。java sdk不提供直接继承自collection的类,java sdk提供的类都是继承自collection的“子接口”如list和set。
  所有实现collection接口的类都必须提供两个标准的构造函数:无参数的构造函数用于创建一个空的collection,有一个collection参数的构造函数用于创建一个新的collection,这个新的collection与传入的collection有相同的元素。后一个构造函数允许用户复制一个collection。
  如何遍历collection中的每一个元素?不论collection的实际类型如何,它都支持一个iterator()的方法,该方法返回一个迭代子,使用该迭代子即可逐一访问collection中每一个元素。典型的用法如下:
    iterator it = collection.iterator(); // 获得一个迭代子
    while(it.hasnext()) {
      object obj = it.next(); // 得到下一个元素
    }
  由collection接口派生的两个接口是list和set。

list接口
  list是有序的collection,使用此接口能够精确的控制每个元素插入的位置。用户能够使用索引(元素在list中的位置,类似于数组下标)来访问list中的元素,这类似于java的数组。
和下面要提到的set不同,list允许有相同的元素。
  除了具有collection接口必备的iterator()方法外,list还提供一个listiterator()方法,返回一个listiterator接口,和标准的iterator接口相比,listiterator多了一些add()之类的方法,允许添加,删除,设定元素,还能向前或向后遍历。
  实现list接口的常用类有linkedlist,arraylist,vector和stack。

linkedlist类
  linkedlist实现了list接口,允许null元素。此外linkedlist提供额外的get,remove,insert方法在linkedlist的首部或尾部。这些操作使linkedlist可被用作堆栈(stack),队列(queue)或双向队列(deque)。
  注意linkedlist没有同步方法。如果多个线程同时访问一个list,则必须自己实现访问同步。一种解决方法是在创建list时构造一个同步的list:
    list list = collections.synchronizedlist(new linkedlist(...));

arraylist类
  arraylist实现了可变大小的数组。它允许所有元素,包括null。arraylist没有同步。
size,isempty,get,set方法运行时间为常数。但是add方法开销为分摊的常数,添加n个元素需要o(n)的时间。其他的方法运行时间为线性。
  每个arraylist实例都有一个容量(capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensurecapacity方法来增加arraylist的容量以提高插入效率。
  和linkedlist一样,arraylist也是非同步的(unsynchronized)。

vector类
  vector非常类似arraylist,但是vector是同步的。由vector创建的iterator,虽然和arraylist创建的iterator是同一接口,但是,因为vector是同步的,当一个iterator被创建而且正在被使用,另一个线程改变了vector的状态(例如,添加或删除了一些元素),这时调用iterator的方法时将抛出concurrentmodificationexception,因此必须捕获该异常。

stack 类
  stack继承自vector,实现一个后进先出的堆栈。stack提供5个额外的方法使得vector得以被当作堆栈使用。基本的push和pop方法,还有peek方法得到栈顶的元素,empty方法测试堆栈是否为空,search方法检测一个元素在堆栈中的位置。stack刚创建后是空栈。

set接口
  set是一种不包含重复的元素的collection,即任意的两个元素e1和e2都有e1.equals(e2)=false,set最多有一个null元素。
  很明显,set的构造函数有一个约束条件,传入的collection参数不能包含重复的元素。
  请注意:必须小心操作可变对象(mutable object)。如果一个set中的可变元素改变了自身状态导致object.equals(object)=true将导致一些问题。

map接口
  请注意,map没有继承collection接口,map提供key到value的映射。一个map中不能包含相同的key,每个key只能映射一个value。map接口提供3种集合的视图,map的内容可以被当作一组key集合,一组value集合,或者一组key-value映射。

hashtable类
  hashtable继承map接口,实现一个key-value映射的哈希表。任何非空(non-null)的对象都可作为key或者value。
  添加数据使用put(key, value),取出数据使用get(key),这两个基本操作的时间开销为常数。
hashtable通过initial capacity和load factor两个参数调整性能。通常缺省的load factor 0.75较好地实现了时间和空间的均衡。增大load factor可以节省空间但相应的查找时间将增大,这会影响像get和put这样的操作。
使用hashtable的简单示例如下,将1,2,3放到hashtable中,他们的key分别是”one”,”two”,”three”:
    hashtable numbers = new hashtable();
    numbers.put(“one”, new intege

 
 
上一篇: 如何设计出具有gui特色的“纯”java程序    下一篇: java入门:java中不同类型的转换和提升
  相关文档
thinking in java第三版读书笔记-第四章:初始化与清理 11-17
?w???p??:java初始化??序 11-17
关于扰乱器与反编译 11-17
用 struts 向数据库中储存图片 11-17
在java中轻松打印文档 11-16
apache服务器配置全攻略 11-17
bean和servlet的企业应用 11-17
netbeans ide 5.0 -- gui的下一次潮流 11-16
为什么要学习java,成为java程序员? 11-17
java网络蚂蚁的制作流程 11-17
软件开发规范(2) 11-17
jdbctm 指南:入门7 - callablestatement 11-17
循速渐进学用session bean(三) 11-16
【开发框架】谈谈对struts多模块的认识 11-16
java对string字符串对象的创建以及管理 (1) 10-08
jdbc接口技术 11-17
java设计模式例子 factorymethod pattern 11-17
使用commons-pool写的数据库连接池 11-17
java程序员需要了解的几个开源协议介绍 11-16
mysql的子类,专门验证登录 passsql 11-17
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息