关闭

Java中的list、set和map详解

发表于:2015-5-20 09:53

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:小松—路飞    来源:51Testing软件测试网采编

  java集合的主要分为三种类型:
  Set(集)
  List(列表)
  Map(映射)
  要深入理解集合首先要了解下我们熟悉的数组:
  数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),而JAVA集合可以存储和操作数目不固定的一组数据。 所有的JAVA集合都位于 java.util包中! JAVA集合只能存放引用类型的的数据,不能存放基本数据类型。
  简单说下集合和数组的区别:(参考文章:《Thinking In Algorithm》03.数据结构之数组)
  <span style="font-family:Microsoft YaHei;font-size:12px;">世间上本来没有集合,(只有数组参考C语言)但有人想要,所以有了集合
  有人想有可以自动扩展的数组,所以有了List
  有的人想有没有重复的数组,所以有了set
  有人想有自动排序的组数,所以有了TreeSet,TreeList,Tree**
  而几乎有有的集合都是基于数组来实现的.
  因为集合是对数组做的封装,所以,数组永远比任何一个集合要快
  但任何一个集合,比数组提供的功能要多
  一:数组声明了它容纳的元素的类型,而集合不声明。这是由于集合以object形式来存储它们的元素。
  二:一个数组实例具有固定的大小,不能伸缩。集合则可根据需要动态改变大小。
  三:数组是一种可读/可写数据结构---没有办法创建一个只读数组。然而可以使用集合提供的ReadOnly方法,以只读方式来使用集合。该方法将返回一个集合的只读版本。</span>
  Java所有“存储及随机访问一连串对象”的做法,array是最有效率的一种。
  1、效率高,但容量固定且无法动态改变。
  array还有一个缺点是,无法判断其中实际存有多少元素,length只是告诉我们array的容量。
  2、Java中有一个Arrays类,专门用来操作array。
  arrays中拥有一组static函数,
  equals():比较两个array是否相等。array拥有相同元素个数,且所有对应元素两两相等。
  fill():将值填入array中。
  sort():用来对array进行排序。
  binarySearch():在排好序的array中寻找元素。
  System.arraycopy():array的复制。
  若撰写程序时不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库,array不适用。所以就要用到集合。
  那我们开始讨论java中的集合。
  集合分类:
  Collection:List、Set
  Map:HashMap、HashTable
  1.1 Collection接口
  Collection是最基本的集合接口,声明了适用于JAVA集合(只包括Set和List)的通用方法。 Set 和List 都继承了Conllection,Map。
  1.1.1  Collection接口的方法:
  <span style="font-weight: normal;">boolean add(Object o)      :向集合中加入一个对象的引用
  void clear():删除集合中所有的对象,即不再持有这些对象的引用
  boolean isEmpty()    :判断集合是否为空
  boolean contains(Object o) : 判断集合中是否持有特定对象的引用
  Iterartor iterator()  :返回一个Iterator对象,可以用来遍历集合中的元素
  boolean remove(Object o) :从集合中删除一个对象的引用
  int size()       :返回集合中元素的数目
  Object[] toArray()    : 返回一个数组,该数组中包括集合中的所有元素 </span>
  关于:Iterator() 和toArray() 方法都用于集合的所有的元素,前者返回一个Iterator对象,后者返回一个包含集合中所有元素的数组。
  1.1.2  Iterator接口声明了如下方法:
  hasNext():判断集合中元素是否遍历完毕,如果没有,就返回true
  next() :返回下一个元素
  remove():从集合中删除上一个有next()方法返回的元素。
31/3123>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号