Java基础笔记8列集合(Collection、List、Set)、泛型.docxVIP

Java基础笔记8列集合(Collection、List、Set)、泛型.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java基础笔记8列集合(Collection、List、Set)、泛型

day 14 集合类 14-01 集合类: 为什么出现集合类? 面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式。 数组和集合同是容器,有何不同? 数组虽然可以存储对象,但长度是固定的,集合长度是可变的,数组中可以存储基本数据类型,集合只能存储对象。 集合类的特点: 集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象。 集合框架 Collection: List:ArrayList ,LinkedList ,Vector Set:HashSet ,TreeSet 为什么会出现这么多的容器? 因为每一个容器对数据的存储方式都有不同,这个存储方式称之为:数据结构 14-02 Java.lang包里的类不需要手动导入,系统自动导入。 ArrayList al = new ArrayList() ; al.add(Object obj); //可以添加任意类型的对象,所以参数是Object类型。 添加字符串类型类://al.add(“java01”); al.add(“java02”); al1.addAll(al2); 打印集合:sop(al);//---[java01,java02] 打印集合个数:sop(al.size) ;//---1 ; 3.删除元素:al.remove(“java02”); sop(al);---[java01] 清空集合:al.clear() ; 4.判断元素:sop(al.contains(“java03”));--false al1.containsAll(al2); sop(al.isEmpty()); 1.add方法的参数类型是Object,以便于接收任意类型对象 2.集合中存的是对象的引用(地址),不是实体 取交集:al1.retainAll(al2) ;//只保留al1与al2内相同的部分 al1.add(“java01”); al1.add(“java02”); al2.add(“java01”); al2.add(“java03”); al1.retainAll(al2) ;sop(al1);---java01 删除:al1.removeAll(al2) ;---java02 。删除与al2相同的元素(保留与al2不同的元素) 14-03 元素的取出: Iterator it = new iterator();//接口,建立接口子类对象。 获取迭代器,用于取出集合中的元素。 while(it.hasNext()) //it.hasNext():判断集合中还有没有元素,没有返回false { sop( it.next() ) } //it.next():取出集合中元素 for( Iterator it = new iterator() ; it.hasNext() ; ) { sop( it.next() ) } //可以优化内存。 什么是迭代器:其实就是集合的取出元素的方式。 迭代器:内部类。实现了Iterator接口的每一个容器的内部对象。 Iterator:该对象必须依赖于具体容器,因为每一个容器的数据结构都不同,所以该迭代器对象是在容器中进行内部实现的。内部类 14-04 List:元素是有序的,元素可以重复,因为该集合体系有索引 Set:元素是无序的,元素不可以重复。 List特有方法:凡是可以操作角标的方法都是该体系特有的方法 增:add(index,element) ; assAll(index,Collection); 删:remove(index); 改:set(index,element); 查:get(index); subList(from,to);获取从from角标到to-1角标的元素 listIterator() ; 14-05 CollectionDemo 列表迭代器:listIterator 在迭代过程中,准备添加或者删除元素 不能并发访问。迭代里面操作集合方法,有安全隐患,编译会抛出异常。 List集合特有的迭代器ListIterator:是Iterator的子接口。 在迭代时,不可以通过集合对象的方法操作集合中的元素,因为会发生ConcurrentModificationException异常。所以,在使用迭代器时,只能选用迭代器的方法操作元素,可是Iterator方法是有限的,只能对元素进行判断,取出,删除操作。 如果想要其他操作如添加,修改等,就需要使用器子接口:ListIterator。 该接口只能通过List集合的ListIterator方法获取。 hasPrevious:返回查看迭代有没有前一个元素。没有返回false。

文档评论(0)

mi80868668 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档