容器是什么?通俗的讲容器指可以装其它东西的器皿,前面我们提到的数组便是容器的一种,容器的概念在JAVA中便可以理解为用来存储其它对象的器皿。本篇就让我们一起来认识一下JAVA为我们提供的容器类。

 1、容器API:

  J2SDK提供的容器API位于java.util包内,容器API的类图结构如下图所示:

   

 2、JAVA容器的组成:

  Collection接口——定义了存取一组对象的方法,其子接口Set和List分别定义了存取方式。Set中的数据对象没有顺序但不可以重复;List中的对象有顺序且可以重复,List又被细分为LinkedList和ArrayList,从名字上应该可以看出它的不同,LinkedList以链表的方式来存储数据,ArrayList则以数组的方式来存储数据。说完了Collection接口,下面我们看一下Map接口,Set和List都是单值存储,而Map则提供的是一种键值对的方式存储数据,键和值之间一一映射。

 3、Collection接口定义的方法:

  int size():容器中对象的数目

  boolean isEmpty():是否为空

  void clear():清空

  boolean contains(Object element):是不是包含element对象

  boolean add(Object element):添加element的对象

  boolean remove(Object element):移除element对象

  Iterator iterator():返回一个Iterator对象,用于遍历容器中的对象

  bollean containsAll(Collection c):是否包含c容器中的所有对象

  boolean addAll(Collection c):把c容器中的所有对象添加到容器中

  boolean removeAll(Collection c):从容器中移除C容器中存在的所有对象

  boolean retainAll(Collection c):求当前的集合类与C容器的交集

  Object[] toArray():把容器中的所有对象转换到对应的数组中

 4、Iterator接口:

  所有实现了Collection接口的容器都有一个iterator方法,用于返回一个实现了Itertaor的对象。Iterator对象称为迭代器,用于方便的实现对容器中元素的遍历。

 5、Iterator接口的方法:

  boolean hasNext():判断游标右边是否有元素

  Object next():返回游标右边的元素,并将游标移动到下一个位置。

  void remove():删除游标左边的元素,并将游标移动到下一个位置,该方法一次只能执行一次

public class Iter {/*** @param Interator接口*/public static void main(String[] args) {Collection coll = new HashSet();coll.add(new Integer(1));coll.add(new Integer(2));coll.add(new Integer(3));Iterator it = coll.iterator();while(it.hasNext()){//判断下一位置是否为空Integer i = (Integer) it.next();if(!i.equals(new Integer(1))){System.out.println(i);}else{it.remove();//移除
            }}}
}

 6、增强的for循环:

  JAVA SDK1.5新增的一个方法,对于遍历array或Collection的时候相当简便。缺陷在于对于数组元素不能方便的访问下标值;对于集合与Iterator相比不能方便的删除容器中的元素。结论:除了简单的遍历和读取其中的内容外,不建议使用增强的for循环。使用方法:

public class test {/*** @param 增强for循环*/public static void main(String[] args) {Collection<String> coll = new ArrayList<String>();coll.add(String.valueOf("a"));coll.add(String.valueOf("b"));coll.add(String.valueOf("c"));for(String str : coll){System.out.println(str);}}
}

 7、Set接口:

  Set接口是Collection接口的子接口,Set接口没有提供额外的方法,但实现了Set接口的容器类中的元素是没有顺序,并且不可以重复的。Set容器类似于数学中集合的概念,J2SDK API中所提供的Set容器类有HashSet和TreeSet等。

public class test {/*** @param Set接口*/public static void main(String[] args) {Collection coll = new HashSet();coll.add("hello");coll.add("word");coll.add(new Integer(100));System.out.println(coll);}
}

 8、List接口:

  List接口是Collection接口的子接口,List容器的中的元素没有顺序,可以重复。List容器中的元素都对应一个整型序号记载着其在容器中的位置。J2SDK API中所提供的List容器类有ArrayList和LinkList等。

 9、常用方法:

  void sort(List):对List中的元素进行排序

  void shuffle(List):对List中的元素进行随机排序

  void reverse(List):对List中的元素进行逆袭排序

  void fill(List, Object):用一个特定的对象重写List容器

  void copy(List dest, List src):将src容器中的元素拷贝到dest容器中

  int binarySearch(List, Object):对顺序的List容器,采用折半查找法寻找特定的对象

public class test {/*** @param List接口*/public static void main(String[] args) {List l1 = new LinkedList();List l2 = new LinkedList();for(int i=0; i<5; i++){l1.add(i+1);}for(int i=0; i<5; i++){l1.add('a');}System.out.println(l1);//原始顺序Collections.shuffle(l1);//随机排序
        System.out.println(l1);Collections.reverse(l1);//倒序排序
        System.out.println(l1);Collections.sort(l1);//排序
        System.out.println(l1);System.out.println(Collections.binarySearch(l1, 3));//折半查找Collections.copy(l2, l1);//拷贝
        System.out.println(l2);}
}

 10、Comparable接口:

  List容器中的元素可以进行排序,那么它是根据什么进行的排序呢?所有可以进行排序的类都实现了java.lang.Comparable接口,Comparable接口只有一个方法:public int CompareTo(Object obj);方法。返回值:0代表this==obj;正数代表this>obj;负数代表this<obj。实现了Comparable接口的类通过实现CompareTo方法从而定义该类对象的排序方法。对姓名排序的例子:

public class Name implements Comparable{/*** @param Comparable接口*/private String lastName;private String fastName;public String getLastName() {return lastName;}public void setLastName(String lastName) {this.lastName = lastName;}public String getFastName() {return fastName;}public void setFastName(String fastName) {this.fastName = fastName;}public int compareTo(Object arg0) {Name name = (Name)arg0; int lastCmp = lastName.compareTo(name.lastName);return (lastCmp!=0 ? lastCmp : fastName.compareTo(name.fastName));}
}

 11、Map接口:

  实现了Map接口的类用来存储键--值对,Map中存储的值通过键来标识,故而Map中的键不能重复。

 12、Map常用方法:

  Object put(Object key, Object value):添加元素

  Object get(Object key):取出键值key对应的value值

  Object remove(Object key):移除键值key对应的value值

  boolean containsKey(Object key):判断Map容器中是否存在键值key

  boolean containsValue(Object value):判断Map容器中是否存在value值

  int size():返回Map容器的长度

  boolean isEmpty():判断Map容器是否为空

  void clear():清空Map容器

  对于JAVA容器这一章就总结到这里,对于自动打包和解包、泛型,由于文字描述的局限,就不再这里讨论了,如果你有好的理解,还望留言讨论。

  

转载于:https://www.cnblogs.com/AndroidJotting/p/4337275.html

javase基础复习攻略《七》相关推荐

  1. javase基础复习攻略《六》

    学习JAVA的同学都知道,sun为我们封装了很多常用类,本篇就为大家总结一下我们经常使用的类.上一篇博客一位朋友留言问我String是不是引用数据类型?我通过查找资料发现String属于应用数据类型, ...

  2. javase基础复习攻略《三》

    编程语言的发展: 机器语言--直接由计算机的指令组成,指令.地址.数据都是以"0"和"1"的符号串组成,可以被计算机直接执行. 汇编语言--用容易理解和记忆的符 ...

  3. 计算机考研最后四十天,2021考研最后四十天冲刺复习攻略

    2021考研最后这一冲刺阶段,不仅要对以往学过的知识做强化梳理和查缺补漏,还要集中精力做好英语作文.政治等部分的突击学习.因此,在这个紧要的关头,千万不要吝啬你的付出,一定要把每一项复习任务都要落到实 ...

  4. 考研政治|分析大题复习攻略

    考研政治|分析大题复习攻略 不知道大家有没有听过下面这句话:"考研政治重点在于选择题得分要高,因为大题拉不开差距,大家的分数普遍都是三十几."确实,这句话不错,考研政治要拿高分必须 ...

  5. 2019学硕计算机分数,2019计算机考研408分数要求以及复习攻略?

    2019计算机考研408分数要求以及复习攻略? 2018-05-08 16:49 | 考研集训营 2019考研计算机考研408不同于802的考试,统考408一般难度超级大,许多考过的考生都感觉很难,因 ...

  6. 计算机考研寒假可以做什么,计算机考研寒假复习攻略,边玩边学!

    寒假来了,有的学校已经放假了.19考生可能还不着急复习,但是对于计算机专业考研来说,如果你决定考研,基础还不是很好或者是跨专业,你就须要把考研复习这件事儿放在心上了!又想过好年,又想复习,这份寒假复习 ...

  7. 考研计算机组成原理难度,考研计算机组成原理特点及复习攻略

    摘要: 考研计算机组成原理特点及复习攻略,新东方在线编辑收集整理,为考研考生备考使用,预祝大家考研备考顺利,成功进入梦想的院校. 组成原理内容比较零乱,条理有点繁杂:并且计算机是一个内部运行状态难以直 ...

  8. 计算机专业课考研攻略,考研计算机专业课组成原理特点及复习攻略

    考研复习是一个长期积累的过程,计算机考研复习中,处于复习基础阶段的考生要特别注意依据各科的特点准确把握复习的关键及难点,严格依据最新考纲的规定各个击破,方可为整体的复习打下良好基础,保证后期复习的顺利 ...

  9. 计算机网络期末复习攻略

    计算机网络期末复习攻略 一.名词解释 IP:Internet Protocol 网际互连协议 IPCP:IP Control Protocol IP控制协议 ARP:Address Resolutio ...

最新文章

  1. [转载]2000/XP下删除隐藏旧网卡方法
  2. 逍遥法外第一季/全集How To Get Away With Murder迅雷下载
  3. C++语言基础 —— 数组
  4. mysql source code_Source Code
  5. mysql检索面试题目_MySQL面试题目二十七道整理
  6. JavaScript 对象总结
  7. 服务端指南 数据存储篇 | 聊聊 Redis 使用场景(转)
  8. 李宏毅机器学习——线性回归
  9. 动态路由之OSPF(开放式最短路径优先协议)
  10. Excel单元格格式选择货币格式US$时变成US$¥
  11. Zeppelin0.8.1上操作hive(使用jdbc解释器)
  12. otl mysql 下载_OTL mySQL
  13. 数据结构与算法 c++描述 目录与源码
  14. 【ESP 保姆级教程】疯狂传感器篇 —— 案例:Mega + ESP8266 + MQ2烟雾 + MQ3酒精 + MQ7一氧化碳+ OLED + 阿里云物联网平台 + 微信小程序
  15. phalcon mysql in_phalcon:跟踪sql语句
  16. 里氏替换原则——举例说明Java设计模式中的里氏替换原则
  17. 毕业论文写作中数据获取与查询
  18. 【接口篇 / Wan】(5.2) ❀ 04. 多条宽带冗余 ❀ FortiGate 防火墙
  19. ossec开源入侵检测系统安装配置
  20. 从网络安全热门岗位看红蓝对抗发展趋势

热门文章

  1. MFC中SQLite数据库的使用
  2. linux驱动分离分层的概念
  3. 解决解决鼠标右键被锁定
  4. [转]项目失败的经验
  5. 感染EXE文件代码(C++)
  6. GridView详解
  7. 在 ASP.NET MVC 3 中应用 KindEditor
  8. FTP的主动模式与被动模式
  9. python dash_Dash是Databricks Spark后端的理想基于Python的前端
  10. 数据科学家 数据工程师_数据科学家应该对数据进行版本控制的4个理由