集合框架

集合框架概述

数组和集合的区别

长度

数组的长度固定不变的

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

内容

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

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

数据类型

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

集合只能存储引用类型

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

集合框架体系图

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);

               }



       }

}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容

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