第9章集合类.docVIP

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

集合类 概述 容器: 数组要求长度确定,可以存放基本数据,引用类型数据。 集合类:JDK中设计了这样一种类,功能用于存储各种各样方式的数据。一般也称为容器类。容器类JDK包括一系列的接口、类,因此对这样的接口和类的设计统称为容器框架。动态添加,不用受长度的限制。 实现原理:数组的方式(ArrayList);链表的方式(LinkedList)。 Java的集合类是一种特别有用的工具类,一般包括List、Map、Set三个系列。 Set代表的是无序的,不可重复的集合。【重写equals方法和hashCode方法】 List代表的是有序的,可重复的集合。 Map代表的是键值对的形式,代表具有映射关系的集合。【key --- 》 value】 Collection和Collections区别? Collection是集合类的父接口。 Collections是针对集合的工具类。 final、finally、finalize三个有什么区别? 在集合框架中,提供的存储方式分类: 按照索引值操作数据(get方法 【get(int index)】 ) 实现这种类型的类一般都实现java.util.Collection接口。 按照名称操作数据(get方法 【get(String key)】) 实现这种类型的类一般都实现java.util.Map接口。 这里按照索引值操作继续细化: 允许重复元素 这些类都实现java.util.List接口 不允许重复元素 这些类都实现java.util.Set接口 Iterator:迭代器,主要用于做数据输出。 ListIterator:Iterator子接口,可以进行逆序的输出。 Collection接口 public static void main(String[] args) { StackString s = new StackString(); s.add(asad1);//元素添加 s.add(asad2); s.add(asad3); s.add(asad4); StackString s1 = new StackString(); s1.addAll(s);//添加容器 Object[] obj = s1.toArray();//将栈转换为数组 for (Object o : obj) { System.out.println(o); } System.out.println(s1.size());//测试栈中包含元素大小 System.out.println(s1.contains(as));//测试栈中是否包含某元素 IteratorString iter = s1.iterator();// 将Stack转变为迭代器 while (iter.hasNext()) {// 判断迭代器中是否有下一个元素 String o = iter.next(); // 取出迭代器中元素 System.out.println(o); } } 作业: 利用Stack类,存储10个学生。获取有多少个学生?测试是否包含某个学生?使用普通的循环遍历学生的信息?使用迭代器的方式遍历学生信息? 查API:Collection、Stack public class Student { private String name; private int age; public Student(String name, int age) { super(); = name; this.age = age; } public String getName() { return name; } public void setName(String name) { = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; }; public Student(){ } } public static void main(String[] args) { StackStudent s = new StackStudent();//利用泛型限制容器中只能存放Student类 Student st =null; for(int i= 0 ; i10; i ++){ s.add(new Student(王+i,new Random().nextInt(99))); s.add(st); } System.o

文档评论(0)

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

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

1亿VIP精品文档

相关文档