欢迎来到天天文库
浏览记录
ID:35315430
大小:121.32 KB
页数:8页
时间:2019-03-23
《黑马程序员java培训就业班笔记day17(集合框架set)总结》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、Day17总结1、LinkedList:特有方法:1、增加:addFirst()addLast()JDk1.6之后出现了替代方法BooleanofferFirst()BooleanofferLast()实现代码:Publicstaticvoidmain(String[]args){LinkedLislink=newLinkedList();Link.addFirst("abc1");Link.addFirst("abc2");Link.addFirst("abc3");Link.addFirst("abc4");While(!link.isEmpty()){//此方法可以按照顺序
2、取出元素,但是被删除,可以去模拟一些简单的数据结构Sop(link.removeLast());//abc1、abc2、abc3、abc4}}重点:模拟堆栈、队列这两种常见的数据结构;实现代码:队列:先进先出Publicstaticvoidmain(String[]args){DuiLied=newDuiLie();d.myAdd("abc1");d.myAdd("abc2");d.myAdd("abc3");While(!d.isNull()){//判断是否有元素Sop(d.myGet());}}ClassDuiLie{PrivateLinkedListlink;DuiLie(
3、){Link=newLinkedList();}提供添加元素的方法PublicvoidmyAdd(Objectobj){link.addFirst(obj);//这里修改为link.addLast()就是堆栈}提供获取元素的方法PublicObjectmyGet(){Returnlink.removeLast();}判断集合中是否有内容PublicbooleanisNull(){Returnlink.isEmpty();}}1、获取:ObjectgetFirst()获取对象,不删除,如果集合中没有元素会抛出NoSuchElementException;ObjectgetLast(
4、);JDK1.6后ObjectpeekFirst()Objectpeeklast()2、获取对象:ObjectremoveFirst()获取到元素,但是删除了。ObjectremoveLast();ObjectpollFirst()ObjectpollLasr()1、Set集合:无序、不重复、该接口中的方法和Collection接口中的方法一致。
5、--HashSet:低层哈希表数据结构,不同步的,它保证元素唯一性的方式:根据元素的两个方法来完成的,一个是hashCode、一个equals。只有当hashCode方法算出的哈希值相同时,会再次判断两个元素的equals方法是否为tu
6、re;如果是true说明两个元素相同,不存储,所以往hashSet集合中存储自定义对象时,要覆盖hashCode、equals方法,通过自定义独享具备的特有数据来定义hashCode、equals的具体实现。哈希结构表分析:Hash表和数组表的比较,哈希表数据结构是按照元素的特征通过指定的功能算出该元素的位置,这种方式查找时候比较快,不用去遍历整个数组,直接用要查找的数据进行元素即可,存入其他的数据类型也可以,比如说字符串,只要定义一个功能算法对其进行运算即可,注意:哈希值冲突,比如31%10和21%10最后的值都是1,只是往1角标中存储就冲突了,怎么去解决这个问题呢?哈希表有种
7、特殊的方式:再散列方式(就是再把这个数据进行取模,算出其他的位置),除此之外还有另外一种方式:当算到相同的值时,就在该冲突的位置的基础上向下顺延一个位置出来,这时候便不再冲突了,如过还有值冲突就继续向下顺延,上图结构通过equals方法来判断对象是否想用,这个方法只有在哈希值一样的时候才会用到。实现代码:需求:存储自定义对象,比如Person,同姓名和同年龄视为同一个人,是相同元素。hashSeths=newhashSet();Hs..add(newPerson("lisi1",20));Hs..add(newPerson("zhangsan",20));Hs..add(newP
8、erson("wangwu",20));Hs..add(newPerson("sunba",20));Hs..add(newPerson("zhangsan",20));取出来Iteratorit=hs.iterator();While(it.hasNext()){Personp=(Person)it.next();Sop(p.getName()+p.getAge());}ClassPerson(){PrivateStringname;Privateintage;Person(S
此文档下载收益归作者所有