- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Collection库是在java.util包下的一些接口和类,只能用来存放对象,不像数组那样有容量大小的限制。
常见的问题:
是否要求内部元素同为一个类型的元素
是否线程安全的
是否允许元素重复
如何判断两个元素是否相同 hashcode() equals()
Collection接口
特性:其中的元素没有特定的顺序,元素也可以重复。
该接口的实现类是AbstractCollection类,其两个子类是AbstractList和AbstractSet。均为抽象类。
Set接口
特性:存放在里面的元素没有特定的顺序,但元素不可以重复(对数据对象而言其值相同则只存一份)。
HashSet类实现了Set接口。
子接口为SortedSet,实现该子接口的类为TreeSet类。
TreeSet中的数据不能重复,且数据类型需相同。
List接口
特性:数据具有特定的顺序,元素是可重复的。
实现该接口的类有LinkedList和ArrayList
Iterator接口
Collection对象都有一个iterator方法产生Iterator对象
而List中的数据是有序的,因而还有个特别的Iterator接口,即ListIterator,可以向前和向后遍历list。
Map接口
不是继承自Collection接口,需要存放关键值key和一个对应的数据value。
实现其接口的有HashMap类和TreeMap类,其中TreeMap类还实现了SortedMap接口。
6.JDK1.1中的Collection库只有List和 Map,前者对应的实现类是Vector,后者对应的实现类是Hashtable类。Vector还有个子类,Stack。
Iterator有对应的接口Enumeration接口。
新旧库的差别:
旧的类是Tread-Safe的,即Hashtable、Vector类中的方法是synchronized的,在多线程的程序中使用它们来存放数据可以确保数据的一致性,但在单线程的程序中使用则会降低效率。
新的库中的类执行效率会比较快,但用到Threads时就需要小心。但新的库也可以产生有synchronized的Collection对象,使用Collection类所提供的类方法“synchronizedXXXX”,来将XXXX接口转换成有synchronized保护的XXXX接口。
一、数组、集合
数组、集合:都是一种容器,用一个对象管理多个对象;
数组:不能自动增长;只能存放同类型的元素
集合:能自动扩容;部分集合允许存放不同类型的元素;
二、学习这些集合类要掌握哪些东西:
1)怎样得到(选择)集合对象;
2)怎样添加元素
3)怎样删除元素
4)怎样循环遍历没一个元素
三、list、set、map
collection:父接口;
Set:接口 ---一个实现类: HashSet
List:接口---三个实现类: LinkedList,Vector,ArrayList
SortedSet:接口---实现类:TreeSet
1、List:
List:有序列表,允许存放重复的元素;
实现类:
ArrayList:数组实现,查询快,增删慢,线程不安全,轻量级;下标也是从0开始;
LinkedList:链表实现,增删快,查询慢
Vector:数组实现,线程安全,重量级
2.Set:
无序集合,不允许存放重复的元素;
实现类 HashSet:equals返回true,hashCode返回相同的整数;哈希表;
?
子接口SortedSet:对Set排序 实现类 :TreeSet:二叉树实现的;
看API:E 泛型:表示一个对象;
Iterator:接口,迭代器;
java.util;
hasNext();
next();
remove();
Iterable:可迭代的,访问的 ;
java.lang;实现了可迭代的接口就可以用迭代的方式访问;
只需实现 iterator();方法即可;Iterator iterator();
三种循环的访问方式:
for(int i=0;ilist.size();i++){
System.out.println(list.get(i));
}
? Iterator it=list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
? for--each 循环:
for(Object obj:list){
System.out.println(obj);
}
? ?
只有实现了Iterable接口的才能用第三种;能用第二种的也一定
您可能关注的文档
最近下载
- 迈富时 上市招股说明书.pdf VIP
- 年产3500吨对羟基苯甲酸乙酯(食品添加剂)项目可行性研究报告.docx VIP
- HMMT_-_哈佛-MIT数学竞赛题.pdf
- 资金平衡表.doc VIP
- 小学生四年级上册暑假练字电子字帖生字写字表提前学习练习楷书字帖pdf可打印文件.pdf VIP
- 氢氟酸安全标签.doc VIP
- 2025年全国统一高考生物试卷(江西卷)含答案 .pdf VIP
- 《义务教育数学课程标准(2022年版)》【试题】题库及答案汇总.docx VIP
- 八年级上册历史《中华民族的抗日战争》单元作业设计 (优质案例50页) .pdf VIP
- 商务日语函电第2课 支払い遅延の依頼と回答.ppt VIP
文档评论(0)