集合框架

集合框架概述

数组和集合的区别

长度

数组的长度固定不变的

集合长度是可以根据实际需要改变

内容

数组存储的是同一种类型的元素

集合可以存储不同类型的元素

数据类型

数组可以存储基本数据类型,也可以存储引用数据类型

集合只能存储引用类型

注意:虽然集合不能存储基本数据类型,但是可以存储基本数据类型的包装类类型

集合框架体系图

collection

集合层次结构 中的根接口。Collection 表示一组对象,这些对象也称为 collection 的元素。一些 collection 允许有重复的元素,而另一些则不允许。

一些 collection 是有序的,而另一些则是无序的。JDK 不提供此接口的任何直接 实现:它提供更具体的子接口(如 Set 和 List)实现。


集合的设计

*         因为集合有很多 增删查改的方法,而且集合是一套框架,既然是框架那么每一种集合处理增加删除修改遍历的方式不一样

*  Collection的特点

*          1.部分集合是有序的,部分集合是无序的,这里的有序指的是存储有序

*          2.部分集合是可排序的,部分集合是不可排序

*          3.部分集合是可重复的,部分集合是不可重复,唯一的

*  

*  那么既然每一个集合的特点不一样,那么就取决于所有子类的实现方式不一样,但是我们知道,既然是集合就应该具备集合的特点:

*          1.长度可变的

*                 2.能够存储任意的引用类型

*                 3.具备很多对对象进行增删查改的方法

*                 4.集合也能够存储基本类型的包装类类型,更加扩展了int的一些功能

* 但是实现方式不一样

*                 实现方式不一样取决于底层的数据结构不一样

* 数据结构: 数据的存储方式

* 算法: 递归 冒泡 选择

* 学习集合就一定要学习集合相关的数据结构

*         集合涉及的数据结构: 栈 , 队列, 链表, 数组, 哈希表 , 二叉树

*

* 1.添加功能

*         boolean add(Object obj)

*         boolean addAll(Collection c)

* 2.删除功能

*         void clear()

*  boolean remove(Object o)

*  boolean removeAll(Collection<?> c)

* 3.修改功能

* 4.遍历功能

*  Object[] toArray()

*         Iterator<E> iterator()

*  <T> T[] toArray(T[] a)

* 5.判断功能

*         boolean contains(Object o)

*  boolean containsAll(Collection<?> c)

*  boolean isEmpty()

* 6.其他功能

*  boolean retainAll(Collection<?> c)

* 7.获取集合长度的功能

*  int size()

*         

*/

public class CollectionDemo02 {

       public static void main(String[] args) {

               Collection c = new ArrayList();

               System.out.println(c);

               // boolean add(Object obj)

               c.add("张三");

               c.add("李四");

               c.add("王五");

               System.out.println(c);


               // boolean addAll(Collection c)

               Collection c1 = new ArrayList();

               c1.add("关羽");

               c1.add("赵云");

               c1.add("吕布");

               c.addAll(c1);

               System.out.println(c);

               System.out.println(c1);


               // void clear()

               System.out.println("--------------");

//                c.clear();

               System.out.println(c);

               // boolean remove(Object o)

               System.out.println("remove:" + c.remove("张三"));

               System.out.println(c);


               // boolean removeAll(Collection<?> c)

//                System.out.println("remove:" + c.removeAll(c1));

               System.out.println(c);


               System.out.println("------------------");

               System.out.println("boolean contains(Object o): " + c.contains(""));

               System.out.println("abc".contains(""));


               // boolean containsAll(Collection<?> c)

               System.out.println(c);


               Collection c2 = new ArrayList();

               c2.add("吕布");

               System.out.println("boolean containsAll(Collection<?> c) :" + c.containsAll(new ArrayList<>()));

               System.out.println("boolean containsAll(Collection<?> c) :" + c.containsAll(c2));

               // c: [李四, 王五, 关羽, 赵云, 吕布]   new ArrayList<>(): []


//                c.clear();

               // boolean isEmpty()

//                System.out.println("boolean isEmpty() :" +c.isEmpty());


               // boolean retainAll(Collection<?> c)

               System.out.println(c); // c:[李四, 王五, 关羽, 赵云, 吕布]  交集 [李四,曹操] = c:[李四]

               /*

                * c:[李四, 王五, 关羽, 赵云, 吕布]  交集 [李四,曹操] = c:[李四]

                * c:[李四, 王五, 关羽, 赵云, 吕布]  交集 [李四123,曹操] = c:[]

                * c:[李四, 王五, 关羽, 赵云, 吕布]  交集 [张三, 李四, 王五, 曹操, 关羽, 赵云, 吕布] = c:[李四, 王五, 关羽, 赵云, 吕布]

                */

               Collection c3 = new ArrayList<>();

               c3.add("张三");

               c3.add("李四");

               c3.add("王五");

               c3.add("曹操");

               c3.add("关羽");

               c3.add("赵云");

               c3.add("吕布");

               System.out.println(c3);

//                System.out.println("boolean retainAll(Collection<?> c) " + c.retainAll(c3));

//                System.out.println(c);

               System.out.println("boolean retainAll(Collection<?> c) " + c.retainAll(c3));

               System.out.println(c);

               // 求交集,返回的结果是观察原集合是否发生改变 改变了返回true,没改变返回false


               System.out.println(c.size());


       }

}

/*

* 4.遍历功能

*  Object[] toArray()

*         Iterator<E> iterator()

*                 boolean hasNext(); 判断是否有下一个元素

*                 E next(); 获取下一个元素,并且指针指向下一个元素的位置

*

* java.util.NoSuchElementException

* 异常名称: 没有下一个元素异常

* 产生原因: 迭代器遍历的时候没有下一个元素了

* 解决办法:在迭代器迭代之前做判断

*  <T> T[] toArray(T[] a)

*/

public class CollectionDemo03 {

       public static void main(String[] args) {

               Collection c = new ArrayList();

               c.add("李逵");

               c.add("武松");

               c.add("武大郎");

               System.out.println(c);


               Object[] arrs = c.toArray();

               for (int i = 0; i < arrs.length; i++) {

                       System.out.println(arrs[i]);

               }


               System.out.println(arrs[1]);


               System.out.println("-------------------------");


               // 获取和集合有关的迭代器对象

//                Iterator it = c.iterator();

//                if (it.hasNext()) {

//                        Object oj = it.next();

//                        System.out.println(oj);

//                }

//                if (it.hasNext()) {

//                        Object oj = it.next();

//                        System.out.println(oj);

//                }

//                if (it.hasNext()) {

//                        Object oj = it.next();

//                        System.out.println(oj);

//                }

//                if (it.hasNext()) {

//                        Object oj = it.next();

//                        System.out.println(oj);

//                }

//                

//                Iterator it = c.iterator();

//                while(it.hasNext()) {

//                        Object oj = it.next();

//                        System.out.println(oj);

//                }

iterator接口


对 collection 进行迭代的迭代器。迭代器取代了 Java Collections Framework 中的 Enumeration,迭代器依赖于集合而存在。

boolean hasNext()

       如果仍有元素可以迭代,则返回 true。

E next()

       返回迭代的下一个元素。

注意:

       抛出: NoSuchElementException - 没有元素可以迭代。

void remove()

       返回迭代的当前元素。

迭代器原理


               for(Iterator it = c.iterator();it.hasNext();) {

                       Object oj = it.next();

                       System.out.println(oj);

               }


               System.out.println("-------------------");

               // foreach遍历

               /*

                * foreach就是用来遍历集合或者数组的

                * 格式:

                *         for(元素类型 元素 : 集合或者数组){

                *                 对元素进行响应的操作

                *  }

                */

               for (Object obj : arrs) {

                       System.out.println(obj);

               }


               int[] arr = new int[5];

               arr[0] = 25;

               arr[1] = 235;

               for (int i : arr) {

                       System.out.println(i);

               }



       }

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转载自:Java集合框架实例 1- 介绍 集合是程序和语言的基本思想。应用程序通常都会应用到集合,例如雇员的信息,...
    01_小小鱼_01阅读 428评论 0 1
  • 01_集合框架(对象数组的概述和使用) A:案例演示需求:我有5个学生,请把这个5个学生的信息存储到数组中,并遍历...
    KelvinYip阅读 188评论 0 0
  • 四、集合框架 1:String类:字符串(重点) (1)多个字符组成的一个序列,叫字符串。生活中很多数据的描述都采...
    佘大将军阅读 775评论 0 2
  • 1. 集合介绍 集合是java中提供的一种容器,可以用来存储多个数据。由java基础语法中得知,如果数据多了,可以...
    如果仲有听日阅读 536评论 0 0
  • Java集合框架结构图完整版 在完整版的结构图中Collection集合和Map下有许多未实现的抽象类(Ab...
    LizGbus8阅读 899评论 0 3