一、java集合的分类及相互之间的关系

  Collection接口:向下提供了List和Set两个子接口
    |------List接口:存储有序的,存储元素可以重复

      |------ArrayList(主要的实现类)、LinkList(适用于频繁的插入删除操作)、Vector(古老的实现类,线程安全的)

    |------Set接口:存储无序,元素不可重复

      |------hashSet、LinkHashSet、treeSet

  Map接口:存储 “键-值 ”对的数据

    |------HashMap、LinkedHashMap、HashTable(子类:properties)


二、Collection集合常用的15中方法,下面分别对15种方法进行详解:

  Collection coll=new ArayList();   //创建ArrayList集合对象

方法1. size() :  返回集合中元素的个数;

   coll.size();

方法2. add(Object obj):  向集合中添加一个元素,可以是多种不同的类型;

  coll.add(123);

  coll.add("AA");

  coll.add(new Date());

方法3. addAll(Collection coll):   将行参coll中包含的所有元素添加到当前集合中

  Collection coll1=Arrays.asList(1,2,3);    //将数组转化为一个集合

  coll.addAll(coll1);

方法4. isEmpty():  判断集合是否为空;

  coll.isEmpty();

方法5. clear():  清空集合元素;

  coll.clear();

方法6. contains():  判断集合中是否包含指定的obj元素,包含返回true,否则返回false;(判断依据:根据元素所在类的equals()方法进行判断,如果存入集合中的元素是自定义类的对象,要求自定义类要重写equal() 方法)

  coll.contains("AA");

方法7. containsAll(Collection coll):  判断当前集合中是否包含coll中所有的元素;

  Collection coll1=new ArrayList();

  coll1.add("AA");

  coll1.add(123);

  coll.containsAll(coll1);

方法8. retainAll(Collection coll):  取当前集合和coll的共有的元素,返回给当前集(求两个集合的交集)

  coll.retainAll(coll1);

方法9. remove(Object obj):  删除一个元素,删除成功返回true,否则返回false;

  coll.remove("BB");    //返回false,因为集合coll中不存在元素BB

  coll.remove("AA");    //返回true,元素AA删除成功

方法10. removeAll(Collection coll):  从当前集合中删除包含在集合coll中的元素(求两个集合的差集);

  coll.removeAll(coll1)

方法11: equals(Object obj):  判断两个集合中所有元素是否完全相同; 

  Collection coll2=new ArrayList();

  coll2.add(123);

  coll1.equals(coll2);

方法12: hashCode():  计算机集合中的hash值;

  coll.hashCode();

方法13: toArray():  将集合转化为数组;

  Object obj=coll.toArray();

方法14. iterator():  返回一个Iterator接口实现类的对象,实现集合的遍历;

  Iterator iterator=coll.iterator();

  iterator.next();    //返回集合元素

  while(iterator.hasNext()){  terator.next();  }  //实现元素迭代输出


 二、下面讲解Collection集合的遍历:

  集合正确的遍历方法:

方法1. Iterator迭代器遍历(常用):

  Iterator i=coll.iterator();

  while(i.hasNext()){  i.next();  }

  如下图:i.next()方法最初指向的是Iterator对象集合的初始位置即橙黄色区域的位置,相当于栈 -1的位置,不包含任何集合元素,必须使用i.hasNext()方法判断下一个元素是否为空。

null
123
AA
new Date()
new Person()

  错误的使用方法:

  while(i.next()!=null){  i.next();  }

方法2. 增强for循环遍历:

  for(Object i : coll){  i;  }

方法三:简单for循环遍历:

  for(int i=0;i<coll.size();i++){  coll.get(i);  }


四、List相对于Collection新增加的方法

  List list=new ArrayList();

方法1. Object set(int index , Object obj):  将位置为index的元素更改为obj元素

方法2. Object get(int index):  获取指定位置的元素

方法3. void add(int index , Object obj): 指定位置增加元素

方法4. boolean addAll(int index , Collection eles)

方法5. int indexOf(Object obj):  返回当前对象在集合中首次出现的位置,找不到返回-1

方法6. int lastIndexOf(Object obj):  返回obj元素最后一次出现在集合中的位置

方法7. Object remove(int index):  删除指定位置的元素

方法8. List subList(int fromIndex , int toIndex):获取从fromIndex到toIndex结束的左闭右开的List集合

  

转载于:https://www.cnblogs.com/zk-blog/p/Collection.html

java集合的方法及使用详解相关推荐

  1. java集合框架史上最详解(list set 以及map)

    title: Java集合框架史上最详解(list set 以及map) tags: 集合框架 list set map 文章目录 一.集合框架总体架构 1.1 集合框架在被设计时需满足的目标 1.2 ...

  2. Java集合(四) LinkedList详解

      在上篇文章Java集合(三) ArrayList详解的学习和源码分析中,我们知道ArrayList是以数组实现,它的优势是查询性能高,劣势是按顺序增删性能差.如果在不确定元素数量的情况时,不建议使 ...

  3. Java集合篇:Hashtable原理详解(JDK1.8)

    (本文使用的源码基于JDK1.8的) 一.Hashtable的基本方法: 这部分参考博客:https://blog.csdn.net/chenssy/article/details/22896871 ...

  4. Java集合篇:HashMap原理详解(JDK1.8)

    概述 JDK 1.8对HashMap进行了比较大的优化,底层实现由之前的"数组+链表"改为"数组+链表+红黑树",本文就HashMap的几个常用的重要方法和JD ...

  5. Java集合篇:HashMap原理详解(JDK1.7及之前的版本)

    (本文有关HashMap的源码都是基于JDK1.6的) 摘要: HashMap是Map族中最为常用的一种,也是 Java Collection Framework 的重要成员.本文首先给出了 Hash ...

  6. java handler使用方法_Handler 使用详解

    阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android 本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以下内容: Handler 消息处理机制原理 Han ...

  7. Java基础:方法和类详解

    示例代码: 向方法传递对象: class Block{                            //类Block int a,b,c;                          ...

  8. Java中的方法重载定义详解

     方法重载    方法重载的要求: • 在同一个类中,定义了多个同名的方法,但每个方法具有不同的参数类型或参数个数,这些同名的方法,就构成了重载关系 • 简单来说:同一个类中,方法名相同,参数不同 参 ...

  9. java 线程同步的list_java集合框架线程同步代码详解

    List接口的大小可变数组的实现.实现了所有可选列表操作,并允许包括null在内的所有元素.除了实现List接口外,此类还提供一些方法来操作内部用来存储列表的数组的大小.(此类大致上等同于Vector ...

最新文章

  1. 简单几步写一个laravel扩展包
  2. 如何用Python做三阶拼图?
  3. 【c语言】蓝桥杯算法训练 乘法表
  4. 锋利的JQuery —— DOM操作
  5. Maven 单元测试
  6. HDU- 最大报销额
  7. (二)流--递归算法
  8. 剑指 Offer 43. 1~n 整数中 1 出现的次数(数位dp)
  9. 批量部署Linux操作系统的一场革命----Cobbler
  10. 02 理解==与Equals()的区别及用法 1214
  11. jmeter安装包双击没反应_Jmeter5.0源码在eclipse运行的正确打开方式
  12. linux终端python自动提示
  13. 词频统计——三国人物出场次数统计
  14. 黑色精美大气DJ音乐歌曲网站源码+带WAP手机端
  15. 驱动INF文件解析和 为自己的设备安装指定驱动
  16. Android新浪微博分享
  17. abs在c 语言中的作用是什么意思,abs什么意思 c语言中abs是什么意思
  18. php获取农历日期节日
  19. spring boot微服务项目搭建
  20. c#网页设计 UI —登录注册界面

热门文章

  1. python hook_五分钟内用Python实现GitHook
  2. 利用html制作通讯录_动漫制作软件哪些好用?动漫制作软件推荐
  3. 指针数组 c ++_了解C ++中的数组指针
  4. gson 解析json_Gson示例教程解析JSON
  5. jsoup Java HTML解析器
  6. JSON服务器(json-server)
  7. Hibernate Session get()vs load()实例差异
  8. java组合与继承始示例_Java示例中的组合
  9. 终端IO--unix环境高级编程读书笔记
  10. 开课吧:电商产品数据分析的核心目标是什么?