第二讲List接口和ArrayList类25页PPT课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《第二讲List接口和ArrayList类25页PPT课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第二 List 接口 ArrayList 25 PPT 课件
- 资源描述:
-
1、课程回顾oJava集合框架o数组oArrays类数组与Arrays类 Java 类库提供了一套相当完整的容器类,使用这些类的方法可以保存和操纵对象。o。Java所有所有“存储及随机访问一连串对象存储及随机访问一连串对象”的做的做法,法,数组是最有效率的。是最有效率的。但容量固定且无法动态改变。数组还有一个缺点是,无法判断其中实际存有多少元素,length只是告诉我们数组的容量。oArrays此类包含用来操作数组(比如排序和搜索的各种方法。此类还包含一个允许将数组作为列表来查看的静态工厂。binarySearch()方法例题import java.util.Arrays;public class
2、 Quest public static void main(String args)String colors=blue,red,green,yellow,orange;Arrays.sort(colors);System.out.println(Arrays.deepToString(colors);int s2=Arrays.binarySearch(colors,orange);int s3=Arrays.binarySearch(colors,violet);System.out.println(s2+s3);blue,green,orange,red,yellow2-5本讲内容o泛
3、型泛型oList接口接口oIterator接口、接口、ListIterator接口接口oArrayList类类Collection接口osize()oisEmpty()ocontains(Object)oiterator()otoArray()otoArray(T)oadd(E)oremove(Object)ocontainsAll(Collection)oaddAll(Collection)oremoveAll(Collection)oretainAll(Collection)oclear()oequals(Object)ohashCode()程序举例程序举例迭代器(Iterator)o定义
4、定义n对对 collection 进行迭代的迭代器。进行迭代的迭代器。迭代器取代了 Java Collections Framework 中的 Enumeration。o获取获取niterator():让容器传一个Iterator对象,来访问集合中的元素(单向遍历)o方法方法nnext():返回迭代的下一个元素。第一次调用Iterator的next()方法会返回序列中的第一个元素nhasNext():如果仍有元素可以迭代,则返回 true nremove():从迭代器指向的 collection 中移除迭代器返回的最后一个元素 List接口o结构特点结构特点n有序的有序的Collection(
5、也称序列),(也称序列),使用此接口能够精确的控制每个元素插入的位置。用户能够使用用户能够使用索引索引(元素在(元素在List中的中的位置,从位置,从0开始,类似于数组下标)来访开始,类似于数组下标)来访问问List中的元素,中的元素,这类似于Java的数组。nList允许有相同的元素。允许有相同的元素。o常用实现类ArrayListLinkedList列表中元素列表中元素可重复可重复List接口o常见方法常见方法n对列表元素进行定位(索引)访问对列表元素进行定位(索引)访问n特殊的迭代器特殊的迭代器ListIteratorn搜索指定对象搜索指定对象n在任意位置插入和删除多个元素在任意位置插入
6、和删除多个元素get(i)get(i)、set(i,e)set(i,e)、add(i,e)add(i,e)、romove(i)romove(i)listIterator()listIterator()、listIterator(i)listIterator(i)允许元素插入、替换、允许元素插入、替换、双向访问双向访问contains(o)contains(o)、remove(o)remove(o)、indexOf(o)indexOf(o)、lastIndexOf(o)lastIndexOf(o)addAll(i,c)addAll(i,c)、removeAll(c)removeAll(c)列表迭
7、代器(ListIterator)o可按正或逆向遍历列表、迭代期间可修改列表,并获得迭可按正或逆向遍历列表、迭代期间可修改列表,并获得迭代器在列表中的当前位置。代器在列表中的当前位置。oListIterator没有当前元素。没有当前元素。o光标位置始终位于调用光标位置始终位于调用 previous()所返回的元素和调所返回的元素和调用用 next()所返回的元素之间。所返回的元素之间。o方法方法nadd(e):将指定的元素插入列表 nhasNext():以正向遍历列表时,如果列表迭代器有多个元素,则返回 true nhasPrevious():如果以逆向遍历列表,列表迭代器有多个元素,则返回 t
8、rue nnext():返回列表中的下一个元素 nprevious():返回列表中的前一个元素 nset(e):用指定元素替换 next 或 previous 返回的最后一个元素 nremove():从列表中移除由 next 或 previous 返回的最后一个元素 遍历方法123循环语句循环语句for(int i=0;i;i+)for(int i=0;i;i+)迭代器迭代器Iterator it=list.iterator();Iterator it=list.iterator();while(it.hasNext()E e=it.next();while(it.hasNext()E e=i
9、t.next();forEachforEach结构结构for(E e:list)for(E e:list)ArrayList类o元素在内存中是连续存储的,一个用数组实现的元素在内存中是连续存储的,一个用数组实现的List。o实现了实现了可变大小可变大小的数组的数组。o容量(容量(Capacity)即数组的大小)即数组的大小n默认为默认为10,也可指定其大小,也可指定其大小n可随着不断添加新元素而自动增加可随着不断添加新元素而自动增加n当需要插入大量元素时,我们一般采取预先扩充容量当需要插入大量元素时,我们一般采取预先扩充容量的方案:在插入前可以调用的方案:在插入前可以调用ensureCapac
展开阅读全文