




已阅读5页,还剩46页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第7章Java集合,讲师:宋红康新浪微博:尚硅谷-宋红康,JavaSE知识图解,JAVA发展历程,JAVA环境搭建,基础程序设计,数据类型,流程控制,运算符,数组,面向对象编程,类和对象,属性,方法,设计模式,接口,三大特性,应用程序开发,JDBC,集合,异常处理,类库,多线程,IO,反射,网络,连接Oracle,JAVA新特性,Eclipse使用,泛型,枚举,装箱/拆箱,可变参数,Annotation,本章内容,Java集合框架Collection接口APIIterator迭代器接口Collection子接口之一:Set接口HashSetLinkedHashSetTreeSetCollection子接口之二:List接口ArrayListLinkedListVectorMap接口HashMapTreeMapHashtableCollections工具类,Java集合概述,一方面,面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就要对对象进行存储。另一方面,使用Array存储对象方面具有一些弊端,而Java集合就像一种容器,可以动态地把多个对象的引用放入容器中。Java集合类可以用于存储数量不等的多个对象,还可用于保存具有映射关系的关联数组。,Java集合概述,Java集合可分为Collection和Map两种体系Collection接口:Set:元素无序、不可重复的集合-类似高中的“集合”List:元素有序,可重复的集合-”动态”数组Map接口:具有映射关系“key-value对”的集合-类似于高中的“函数”y=f(x)(x1,y1)(x2,y2),Collection,List,Set,Vector,ArrayList,LinkedList,HashSet,SortedSet,LinkedHashSet,Comparable,Comparator,Collections,Iterator,ListIterator,迭代器,对象排序接口,容器工具类,Collection接口继承树,获取,JDK提供的集合API位于java.util包内,TreeSet,Map接口继承树,Map,Hashtable,HashMap,SortedMap,Properties,LinkedHashMap,TreeMap,y=f(x);y=x*2+3;,Collection接口,Collection接口是List、Set和Queue接口的父接口,该接口里定义的方法既可用于操作Set集合,也可用于操作List和Queue集合。JDK不提供此接口的任何直接实现,而是提供更具体的子接口(如:Set和List)实现。在Java5之前,Java集合会丢失容器中所有对象的数据类型,把所有对象都当成Object类型处理;从Java5增加了泛型以后,Java集合可以记住容器中对象的数据类型,Iteratori=coll.iterator();while(i.hasNext()System.out.println(i.next();,i.hasNext(),i.next(),集合与数组间转换操作,Collection接口方法,Iteratoriterator=coll.iterator();while(iterator.hasNext()System.out.println(iterator.next();,iterator.hasNext(),iterator.next(),使用Iterator接口遍历集合元素,Iterator对象称为迭代器(设计模式的一种),主要用于遍历Collection集合中的元素。所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了Iterator接口的对象。Iterator仅用于遍历集合,Iterator本身并不提供承装对象的能力。如果需要创建Iterator对象,则必须有一个被迭代的集合。,Iteratoriterator=coll.iterator();while(iterator.hasNext()System.out.println(iterator.next();,iterator,iterator.hasNext(),iterator.next(),在调用it.next()方法之前必须要调用it.hasNext()进行检测。若不调用,且下一条记录无效,直接调用it.next()会抛出NoSuchElementException异常。,Iterator接口的方法,使用foreach循环遍历集合元素,Java5提供了foreach循环迭代访问Collection,要遍历的元素类型,要遍历的元素名称,遍历后元素名称,publicclassTestForpublicstaticvoidmain(Stringargs)Stringstr=newString5;for(StringmyStr:str)myStr=atguigu;System.out.println(myStr);for(inti=0;istr.length;i+)System.out.println(stri);,练习:判断输出结果为何?,List接口,Java中数组用来存储数据的局限性List集合类中元素有序、且可重复,集合中的每个元素都有其对应的顺序索引。List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素。JDKAPI中List接口的实现类常用的有:ArrayList、LinkedList和Vector。,List接口,List集合里添加了一些根据索引来操作集合元素的方法voidadd(intindex,Objectele)booleanaddAll(intindex,Collectioneles)Objectget(intindex)intindexOf(Objectobj)intlastIndexOf(Objectobj)Objectremove(intindex)Objectset(intindex,Objectele)ListsubList(intfromIndex,inttoIndex),List实现类之一:ArrayList,ArrayList是List接口的典型实现类本质上,ArrayList是对象引用的一个变长数组ArrayList是线程不安全的,而Vector是线程安全的,即使为保证List集合线程安全,也不推荐使用VectorArrays.asList()方法返回的List集合既不是ArrayList实例,也不是Vector实例。Arrays.asList()返回值是一个固定长度的List集合,List实现类之二:LinkedList,对于频繁的插入或删除元素的操作,建议使用LinkedList类,效率较高新增方法:voidaddFirst(Objectobj)voidaddLast(Objectobj)ObjectgetFirst()ObjectgetLast()ObjectremoveFirst()ObjectremoveLast(),List实现类之三:Vector,Vector是一个古老的集合,JDK1.0就有了。大多数操作与ArrayList相同,区别之处在于Vector是线程安全的。在各种list中,最好把ArrayList作为缺省选择。当插入、删除频繁时,使用LinkedList;Vector总是比ArrayList慢,所以尽量避免使用。新增方法:voidaddElement(Objectobj)voidinsertElementAt(Objectobj,intindex)voidsetElementAt(Objectobj,intindex)voidremoveElement(Objectobj)voidremoveAllElements(),ListIterator接口(了解),List额外提供了一个listIterator()方法,该方法返回一个ListIterator对象,ListIterator接口继承了Iterator接口,提供了专门操作List的方法:voidadd()booleanhasPrevious()Objectprevious()BooleanhasNext()Objectnext(),Iterator和ListIterator主要区别(了解),一、ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历。但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator就不可以。二、ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。三、ListIterator有add()方法,可以向List中插入对象,而Iterator不能。四、都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现。Iterator仅能遍历,不能修改。因为ListIterator的这些功能,可以实现对LinkedList等List数据结构的操作。,Set接口,Set接口是Collection的子接口,set接口没有提供额外的方法Set集合不允许包含相同的元素,如果试把两个相同的元素加入同一个Set集合中,则添加操作失败。Set判断两个对象是否相同不是使用=运算符,而是根据equals方法,Set实现类之一:HashSet,HashSet是Set接口的典型实现,大多数时候使用Set集合时都使用这个实现类。HashSet按Hash算法来存储集合中的元素,因此具有很好的存取和查找性能。HashSet具有以下特点:不能保证元素的排列顺序HashSet不是线程安全的集合元素可以是null当向HashSet集合中存入一个元素时,HashSet会调用该对象的hashCode()方法来得到该对象的hashCode值,然后根据hashCode值决定该对象在HashSet中的存储位置。HashSet集合判断两个元素相等的标准:两个对象通过hashCode()方法比较相等,并且两个对象的equals()方法返回值也相等。,Setset=newLinkedHashSet();set.add(123);set.add(456);set.add(newString(AA);set.add(BB);,LinkedHashSet:使用链表维护了一个添加进集合中的顺序。,hashCode()方法,如果两个元素的equals()方法返回true,但它们的hashCode()返回值不相等,hashSet将会把它们存储在不同的位置,但依然可以添加成功。对于存放在Set容器中的对象,对应的类一定要重写equals()和hashCode(Objectobj)方法,以实现对象相等规则。重写hashCode()方法的基本原则在程序运行时,同一个对象多次调用hashCode()方法应该返回相同的值当两个对象的equals()方法比较返回true时,这两个对象的hashCode()方法的返回值也应相等对象中用作equals()方法比较的Field,都应该用来计算hashCode值,Set实现类之二:LinkedHashSet,LinkedHashSet是HashSet的子类LinkedHashSet根据元素的hashCode值来决定元素的存储位置,但它同时使用链表维护元素的次序,这使得元素看起来是以插入顺序保存的。LinkedHashSet插入性能略低于HashSet,但在迭代访问Set里的全部元素时有很好的性能。LinkedHashSet不允许集合元素重复。,Setset=newLinkedHashSet();set.add(newString(AA);set.add(456);set.add(456);set.add(newCustomer(刘德华,1001);set.add(123);,LinkedHashSet,Set实现类之三:TreeSet,TreeSet是SortedSet接口的实现类,TreeSet可以确保集合元素处于排序状态。Comparatorcomparator()Objectfirst()Objectlast()Objectlower(Objecte)Objecthigher(Objecte)SortedSetsubSet(fromElement,toElement)SortedSetheadSet(toElement)SortedSettailSet(fromElement)TreeSet两种排序方法:自然排序和定制排序。默认情况下,TreeSet采用自然排序。,排序自然排序,自然排序:TreeSet会调用集合元素的compareTo(Objectobj)方法来比较元素之间的大小关系,然后将集合元素按升序排列如果试图把一个对象添加到TreeSet时,则该对象的类必须实现Comparable接口。实现Comparable的类必须实现compareTo(Objectobj)方法,两个对象即通过compareTo(Objectobj)方法的返回值来比较大小。Comparable的典型实现:BigDecimal、BigInteger以及所有的数值型对应的包装类:按它们对应的数值大小进行比较Character:按字符的unicode值来进行比较Boolean:true对应的包装类实例大于false对应的包装类实例String:按字符串中字符的unicode值进行比较Date、Time:后边的时间、日期比前面的时间、日期大,排序自然排序,向TreeSet中添加元素时,只有第一个元素无须比较compareTo()方法,后面添加的所有元素都会调用compareTo()方法进行比较。因为只有相同类的两个实例才会比较大小,所以向TreeSet中添加的应该是同一个类的对象对于TreeSet集合而言,它判断两个对象是否相等的唯一标准是:两个对象通过compareTo(Objectobj)方法比较返回值当需要把一个对象放入TreeSet中,重写该对象对应的equals()方法时,应保证该方法与compareTo(Objectobj)方法有一致的结果:如果两个对象通过equals()方法比较返回true,则通过compareTo(Objectobj)方法比较应返回0,排序定制排序,TreeSet的自然排序是根据集合元素的大小,进行元素升序排列。如果需要定制排序,比如降序排列,可通过Comparator接口的帮助。需要重写compare(To1,To2)方法。利用intcompare(To1,To2)方法,比较o1和o2的大小:如果方法返回正整数,则表示o1大于o2;如果返回0,表示相等;返回负整数,表示o1小于o2。要实现定制排序,需要将实现Comparator接口的实例作为形参传递给TreeSet的构造器。此时,仍然只能向TreeSet中添加类型相同的对象。否则发生ClassCastException异常。使用定制排序判断两个元素相等的标准是:通过Comparator比较两个元素返回了0。,Map接口,Map与Collection并列存在。用于保存具有映射关系的数据:Key-ValueMap中的key和value都可以是任何引用类型的数据Map中的key用Set来存放,不允许重复,即同一个Map对象所对应的类,须重写hashCode()和equals()方法。常用String类作为Map的“键”。key和value之间存在单向一对一关系,即通过指定的key总能找到唯一的、确定的value。,y=f(x),(x1,y1)(x2,y2),Map接口,Map,Hashtable,HashMap,SortedMap,Properties,LinkedHashMap,TreeMap,Map体系的继承树,KeySet,Values,4个Entry,Set,Collection,Set,Map常用方法,添加、删除操作:Objectput(Objectkey,Objectvalue)Objectremove(Objectkey)voidputAll(Mapt)voidclear()元视图操作的方法:SetkeySet()Collectionvalues()SetentrySet(),元素查询的操作:Objectget(Objectkey)booleancontainsKey(Objectkey)booleancontainsValue(Objectvalue)intsize()booleanisEmpty()booleanequals(Objectobj),Map实现类之一:HashMap,Map接口的常用实现类:HashMap、TreeMap和Properties。HashMap是Map接口使用频率最高的实现类。允许使用null键和null值,与HashSet一样,不保证映射的顺序。HashMap判断两个key相等的标准是:两个key通过equals()方法返回true,hashCode值也相等。HashMap判断两个value相等的标准是:两个value通过equals()方法返回true。,Map实现类之二:LinkedHashMap,LinkedHashMap是HashMap的子类与LinkedHashSet类似,LinkedHashMap可以维护Map的迭代顺序:迭代顺序与Key-Value对的插入顺序一致,Map实现类之三:TreeMap,TreeMap存储Key-Value对时,需要根据key-value对进行排序。TreeMap可以保证所有的Key-Value对处于有序状态。TreeMap的Key的排序:自然排序:TreeMap的所有的Key必须实现Comparable接口,而且所有的Key应该是同一个类的对象,否则将会抛出ClasssCastException定制排序:创建TreeMap时,传入一个Comparator对象,该对象负责对TreeMap中的所有key进行排序。此时不需要Map的Key实现Comparable接口,Map实现类之三:TreeMap,TreeMap判断两个key相等的标准:两个key通过compareTo()方法或者compare()方法返回0。若使用自定义类作为TreeMap的key,所属类需要重写equals()和hashCode()方法,且equals()方法返回true时,compareTo()方法应返回0。,Map实现类之四:Hashtable,Hashtable是个古老的Map实现类,线程安全。与HashMap不同,Hashtable不允许使用null作为key和value与HashMap一样,Hashtable也不能保证其中Key-Value对的顺序Hashtable判断两个key相等、两个value相等的标准,与hashMap一致。,Map实现类之五:Properties,Properties类是Hashtable的子类,该对象用于处理属性文件由于属性文件里的key、value都是字符串类型,所以Properties里的key和value都是字符串类型存取数据时,建议使用setProperty(Stringkey,Stringvalue)方法和getProperty(Stringkey)方法,Map实现类之五:Properties,Propertiespros=newProperties();pros.load(newFileInputStream(perties);Stringuser=pros.getProperty(user);System.out.println(user);,操作集合的工具类:Collections,Collections是一个操作Set、List和Map等集合的工具类Collections中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作,还提供了对集合对象设置不可变、对集合对象实现同步控制等方法排序操作
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025广东深圳九州光电子技术有限公司招聘生产主管等2人模拟试卷及答案详解(必刷)
- 2025年甘肃省庆阳市正宁县三嘉乡选聘返乡能人、致富带头人到村任职(兼职)考前自测高频考点模拟试题及答案详解1套
- 2025国网冀北电力有限公司第二批高校毕业生录用人选的模拟试卷附答案详解(模拟题)
- 2025甘肃省兰州市榆中县中医医院春季招聘15人考前自测高频考点模拟试题及答案详解(新)
- 2025年福建省厦门市公安局局属单位公开招聘4人模拟试卷完整答案详解
- 2025安徽合肥滨投文化创意发展有限公司招聘3人考前自测高频考点模拟试题及答案详解(必刷)
- 2025安徽宣城市旌德县兴业融资担保有限公司招聘3人考前自测高频考点模拟试题带答案详解
- 2025湖南怀化市靖州县政务服务中心见习人员招聘模拟试卷及答案详解(名校卷)
- 2025年聊城科技职业学院(筹)公开招聘工作人员(60人)考前自测高频考点模拟试题带答案详解
- 2025安徽远景人力资源管理有限公司驾驶员岗位招聘5人笔试题库历年考点版附带答案详解
- 儿童编发课件图片
- 报废汽车回收公司车间管理制度
- 2025合肥市辅警考试试卷真题
- 2024年安徽国元农业保险股份有限公司招聘笔试真题
- 淘宝客服合同协议书模板
- 骨水泥测试试题及答案
- 职业人群心理健康促进指南 2025
- 无人机教育培训创业计划书
- 咸阳社区面试题及答案
- 电力工程施工进度及安全保障措施
- GB/T 19973.2-2025医疗产品灭菌微生物学方法第2部分:用于灭菌过程的定义、确认和维护的无菌试验
评论
0/150
提交评论