List接口方法、LinkedList方法、Vector集合、Set接口下HashSet、LinkedHashSet集合、HashCode()+equals()方法对于Set接口判断重复的详细细节...

List接口:

看List的介绍,有序的 collection(也称为序列),此接口的用户可以对列表中每个元素的插入位置进行精确地控制(有下标)!用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素!与 set 不同,列表通常允许重复的元素!

//特点:

①   有序序列(怎么存进去可以怎么取出来)!

②   有下标,可以精确控制内部元素!

③   允许存在重复元素,可以通过equals方法比较重复元素!

 

//List接口的子类:

①   ArrayList集合

②   LinkedList集合

List接口:

 

 

①   add(Object e):向集合末尾处,添加指定的元素!

②   add(int index, Object e):向集合指定索引处,添加指定的元素,原有元素依次后移!

③   remove(Object e):将指定元素对象,从集合中删除,返回值为被删除的元素!

④   remove(int index):将指定索引处的元素,从集合中删除,返回值为被删除的元素!

⑤   set(int index, Object e):将指定索引处的元素,替换成指定的元素,返回值为替换前的元素(Set前提必须有这个下标)!

⑥   get(int index):获取指定索引处的元素,并返回该元素!

 

 

 

Iterator并发修改异常:

//示例代码:

public class IteratorDemo {

//在list集合迭代元素中,对元素进行判断,一旦条件满足就添加一个新元素

  

 1    public static void main(String[] args) {
 2 
 3          //创建List集合
 4 
 5          List<String> list = new ArrayList<String>();
 6 
 7          //给集合中添加元素
 8 
 9          list.add("abc1");
10 
11          list.add("abc2");
12 
13          list.add("abc3");
14 
15          list.add("abc4");
16 
17          //迭代集合,当有元素为"abc2"时,集合加入新元素"a"
18 
19          Iterator<String> it = list.iterator();
20 
21          while(it.hasNext()){
22 
23               String str = it.next();
24 
25               //判断取出的元素是否是"abc2",是就添加一个新元素
26 
27               if("abc2".equals(str)){
28 
29                    list.add("a");// 该操作会导致程序出错
30 
31               }
32 
33          }
34 
35          //打印容器中的元素
36 
37          System.out.println(list);
38 
39      }
40 
41 }

 

//运行上述代码发生了错误 java.util.ConcurrentModificationException[L1] (并发修改异常)

// Iterator和增强for在遍历集合的时候不允许操作元素

 

//在迭代器中可以用ListIterator对元素进行操作(重要)

 

List集合存储数据的结构:

堆栈/队列/数组/链表

 

//堆栈特点:

①   先进后出(存进去的元素,要在它后面的元素依次取出后,才能取出该元素)

②   栈的入口,出口的都是栈的顶端位置

③   压栈:就是存元素(把元素存储到栈的顶端位置,栈中已有元素依次向栈底方向移动一个位置)

④   弹栈:就是取元素(把栈的顶端位置元素取出,栈中已有元素依次向栈顶方向移动一个位置)

 

 

//队列特点:

①   先进先出(存进去的元素,要在后它前面的元素依次取出后,才能取出该元素)!

②   队列的入口,出口各占一侧!

//数组特点:

①   查找元素快:通过索引,可以快速访问指定位置的元素

②   增删元素慢:

指定索引位置增加元素:需要创建一个新数组,将指定新元素存储在指定索引位置,再把原数组元素根据索引,复制到新数组对应索引的位置

指定索引位置删除元素:需要创建一个新数组,把原数组元素根据索引,复制到新数组对应索引的位置,原数组中指定索引位置元素不复制到新数组中

(Tips:ArrayList底层是数组)

 

//链表特点:多个节点之间,通过地址进行连接!

①   查找元素慢:想查找某个元素,需要通过连接的节点,依次向后查找指定元素!

②   增删元素快:

增加元素:操作如左图,只需要修改连接下个元素的地址即可!

删除元素:操作如右图,只需要修改连接下个元素的地址即可!

 

总结:ArrayList和LinkedList集合

①   ArrayList集合数据存储的结构是数组结构!元素增删慢,查找快,由于日常开发中使用最多的功能为查询数据、遍历数据,所以ArrayList是最常用的集合

①   LinkedList集合数据存储的结构是链表结构!方便元素添加、删除的集合,实际开发中对一个集合元素的添加与删除经常涉及到首尾操作,而LinkedList提供了大量首尾操作的方法

//因材而用:查询较多用ArrayList,增删较多用LinkedList

LinkedList提供的方法:

 

 

Vector集合:

 

elements()方法相当与Iterator调用iterator()方法返回的迭代器对象!

枚举:

 

 

//Vector集合对ArrayList集合使用的对比—相当于早期的ArrayList,枚举就是早期的Iterator迭代器,所以稍作了解即可。

 

Set集合:

//特点:

①   无序集合

②   没有下标

③   不允许有重复元素

HashSet集合:

此类实现Set接口,由哈希表支持(实际上是一个 HashMap集合)。HashSet集合不能保证的迭代顺序与元素存储顺序相同,HashSet集合,

采用哈希表结构存储数据,保证元素唯一性的方式依赖于:hashCode()与equals()方法

 

HashSet存储数据的结构就是数组和链表的组合(哈希表):

//请参考Object的HashCode方法

//由于Set接口下的HashSet和LinkedHashSet集合不产生下标,所以只能用Iterator迭代器和增强for循环进行遍历

 

默认集合长度为16,加载因子为0.75,也就是当数据存储到16*0.75=12时,自动再增加16的长度

 

HashSet的存储结构:

 

 

①   首先调用String中HashCode方法判断“hello”的哈希值在数组内有没有,如果没有,将哈希值放在数组内第一格,然后将“hello”这个字符串放在对应数组格子下面桶内

②   后面“java”/“nihao”以此类推

③   然后判断最后一个“hello”的哈希值,发现跟第一格格子的“hello”的哈希值相同都是500,然后调用String的equals方法,判断两个“hello”的内容相同,所以最后一个“hello”丢弃

④   假设有一个“pig”的字符串跟第一个“hello”的哈希值相同,则调用equals方法,判断内容不同,则在哈希值为500的数组格子下面新开一个桶放入“pig”值

 

注意是否需要重写HashCode和equals方法,来满足实际业务需求(通过右键Sourse点击出来)

保证有序的Set接口下的集合:LinkedHashSet

ArrayList的containes()方法判断元素是否重复底层原理:

ArrayList的contains方法会使用调用方法时,传入的元素的equals方法依次与集合中的旧元素所比较,从而根据返回的布尔值判断是否有重复元素!此时,当ArrayList存放自定义类型时,由于自定义类型在未重写equals方法前,判断是否重复的依据是地址值,所以如果想根据内容判断是否为重复元素,需要重写元素的equals方法

 

 HashSet集合由于是无序的,其判断唯一的依据是元素类型的hashCode与equals方法的返回结果:

先判断新元素与集合内已经有的旧元素的HashCode值:

如果不同,说明是不同元素,添加到集合!

如果相同,再判断equals比较结果!返回true则相同元素;返回false则不同元素,添加到集合!

可以右键Sourse点出来

转载于:https://www.cnblogs.com/2734156755z/p/9428901.html

diaochoufu7325
关注 关注
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java容器集合equalshashCode+基础数据结构+ArrayList+VectorLinkedList
06-21
其中,equalshashCode方法Java容器集合中两个非常重要的方法,本文将详细介绍这两个方法,并结合ArrayListVectorLinkedList三个常见的容器集合。 一、equals方法 equals方法Java中用于比较两个对象是否...
JAVA.SE List,collections,set接口
01-20
文章目录1List接口1.1 Array List1.2LInkedList2.collections类2.1是一个集合工具类,内部保存的是静态方法2.2可变参数3.set接口3.1set接口的特点3.2hashSet3.3LinkedHashSet3.4TreeSet. 1List接口 List接口继承...
2018-08-03List接口方法+LinkedList方法+Vector集合+Set接口HashSetLinkedHashSet集合+HashCode()+equals()方法对于Set接口判...
weixin_30609331的博客
08-03 64
List接口: 看List的介绍,有序的 collection(也称为序列),此接口的用户可以对列表中每个元素的插入位置进行精确地控制(有下标)!用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素!与 set 不同,列表通常允许重复的元素! //特点: ① 有序序列(怎么存进去可以怎么取出来)! ② 有下标,可以精确控制内部元素! ③ 允许存在重复...
ArrayList,LinkedList,equals,hashcode,String的介绍
wangyin970774934的博客
08-11 328
1、字符串池注意事项: 例1:String str0 = "aaa"; String str1 = "aa"; String str2 = new String("aaa"); String str3 = "a"; String str4 = str1 + str3; String str5 = "aaa"; String str6 = new Strin
Java基础之125 HashSet的特点及使用 126HashSet判断重复值的原理 127 TreeSetLinkedHashSet
C_time的博客
04-21 223
**集合框架Set接口 1、Set接口** public interface Set extends Collection 一个不包含重复元素的 collection。更确切地讲,set 不包含满足 e1.equals(e2) 的元素对 e1 和 e2,并且最多包含一个 null 元素。正如其名称所暗示的,此接口模仿了数学上的 set 抽象。 2、HashSet public class Has...
Java集合详解7:HashSet,TreeSetLinkedHashSet
weixin_30667301的博客
04-13 199
今天我们来探索一下HashSet,TreeSetLinkedHashSet的基本原理与源码实现,由于这三个set都是基于之前文章的三个map进行实现的,所以推荐大家先看一下前面有关map的文章,结合使用味道更佳。具体代码在我的GitHub中可以找到https://github.com/h2pl/MyTech文章首发于我的个人博客:https://h2pl.github.io/2018/05/12...
javaSE LinkedHashSet, 元素不能重复,取出顺序和存放顺序一致
houyanhua1的专栏
06-12 9130
Collection(集合):容器,用于存放对象(引用类型。基本类型需要自动装箱)   查看List(列表):元素有序,元素可以重复 (有索引)。 通过元素的equals()方法判断是否重复。  查看Set(集):元素无序,不可重复 (没有索引)。 遍历只能用Iterator迭代器和增强for, 不能使用普通for遍历。 查看ArrayList(数组列表): 查询快,增删慢。   查看Linked...
集合 List接口 List集合 Set集合 ArrayList LinkedList Vector Set接口 HashSet集合存储数据的结构
taotaoSi的博客
02-25 299
List接口我们掌握了Collection接口的使用后,再来看看Collection接口中的子类,他们都具备那些特性呢?接下来,我们一起学习Collection中的常用几个子类(List集合Set集合)。List接口介绍查阅API,看List的介绍。有序的 collection(也称为序列)。此接口的用户可以对列表中每个元素的插入位置进行精确地控制。用户可以根据元素的整数索引(在列表中的位置)访...
javase学习第二十一天:集合Colletion(List接口:ArrayList+LinkedList+Vector + Set接口HashSet+LinkedHashSet+TreeSet
qq_44724899的博客
09-30 403
学习
Java集合(七)SetHashSetLinkedHashSet、TreeSet
HK的博客
01-09 3138
SetHashSet(无序Set)、LinkedHashSet(有序Set)、TreeSet(排序Set
Java集合_Connection接口(List接口(ArrayList&LinkedList&Vector实现类区别)、Set接口(HashSet&TreeSet实现类区别))源码剖析
斗鹰的技术专栏
09-22 1042
前面重点说的差不多了,今天讲讲集合中关于Connection接口中的常用List接口Set接口吧,权当自己复习过程了,自己在梳理一遍,有空闲读者也试试这种方式,整个知识的体系架构就在脑海里了存着了,今天先说到这那么开始今天的主题吧。 Connection 1、Connection接口以及常用子接口的概述。 |---Collection接口:存储的是一个一个的数据 ...
Java遍历集合方法分析(实现原理、算法性能、适用场合)
11-23
Java语言中,提供了一套数据集合框架,其中定义了一些诸如ListSet等抽象数据类型,每个抽象数据类型的各个具体实现,底层又采用了不同的实现方式,比如ArrayListLinkedList。 除此之外,Java对于数据集合的遍历...
简单了解java集合框架LinkedList使用方法
08-18
主要介绍了简单了解java集合框架LinkedList使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
java集合 collection-list-LinkedList详解
08-31
下面小编就为大家带来一篇java集合 collection-list-LinkedList详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
【redis的基本数据类型】
m0_50116974的博客
06-13 528
压缩列表的基本信息包括压缩列表的大小,压缩列表的长度以及最后一个entry的偏移,之所以要有这个偏移,是为了找到最后一个entry,而每个entry都记录上一个元素的大小,通过计算就知道上一个entry的地址,这样方便的从后向前进行遍历。的结构,其分为两部分,8字节的Redis对象元数据信息,8字节的指针,其中Redis对象的元数据信息存储了类型的LRU信息,真正的编码格式等等,而如果字符串存储的是数字类型,则复用了8字节的指针的位置。的操作,但是当列表的元素非常少的时候,其内部使用。
【STM32】基于RTOS的CAN异步接收转发数据
MYLK的博客
06-15 236
现象:全局变量在 CAN 中断中存储数据,并设置同步标志,在主程序中检测标志后,打包并转发 CAN 数据,会出现 CAN 数据错乱现象分析:CAN 数据打包处理过程中,新的数据到来,导致数据包部分覆盖;解决方法:1. 在打包过程中,使用中断屏蔽,保护全局 CAN 数据;2. 使用环形缓冲区保存数据;3.使用队列同步数据方法分析:方法1裸机平台最简单,但会造成中断响应不及时,丢失部分数据,同样会干扰其他中断数据的接收,比如串口中断等;方法2需要对数据结构进行处理,协商存放和取出的规则;
基于JavaScript 如何实现爬山算法以及优化方案
乐闻世界
06-10 1337
爬山算法(Hill Climbing Algorithm)是一种常见的启发式搜索算法,常用于解决优化问题。其核心思想是从一个初始状态出发,通过逐步选择使目标函数值增大的邻近状态来寻找最优解。接下来,我们将通过 JavaScript 实现一个简单的爬山算法,帮助大家理解其原理和应用。从一个初始状态开始。评估当前状态的目标函数值。在当前状态的邻居中选择一个目标函数值更大的状态。如果找到了更优的邻居,则移动到该邻居并重复步骤2和步骤3。如果没有更优的邻居,则算法结束,当前状态即为局部最优解。
背包问题—动态规划
weixin_50470247的博客
06-10 145
与找521 零钱兑换的方式的区别,这个是排列,顺序不同,也统计次数。01背包问题:没有物品(元素)只能选择1次。完全背包,物品(元素)个数有无限个。
论文阅读笔记:DepGraph: Towards Any Structural Pruning
最新发布
HollowKnightz的博客
06-15 832
论文阅读笔记:DepGraph: Towards Any Structural Pruning
关于List接口及ArrayList接口LinkedList接口中常用方法的练习
05-19
好的,下面给你提供一些关于List接口及其子接口ArrayListLinkedList中常用方法的练习题。 1. 创建一个ArrayList,向其中添加5个元素,然后使用for循环遍历输出每个元素。 2. 创建一个LinkedList,向其中添加10个...

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
写文章

热门文章

  • 面向对象测试题 2323
  • transition-duration 属性 2269
  • 构造方法练习题 979
  • JAVASE安装 819
  • 6.2 HTML控制标签格式 631

您愿意向朋友推荐“博客详情页”吗?

  • 强烈不推荐
  • 不推荐
  • 一般般
  • 推荐
  • 强烈推荐
提交

最新文章

  • DBUtils和连接池
  • 动态页面技术(JSP/EL/JSTL)
  • 会话技术Cookie&Session
2018年74篇

目录

目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43元 前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值

两个鬼故事手机免费看赘婿电视剧全集你是主人我是仆无修版投之家视死忽如归写给医院起名seaofthieves死或生加强版2018年狗狗宝宝起名大全男宝宝生日起名这世界那么多人歌词中国起重机排名企业富国天博净值给足球队起名奶茶七分甜姓氏三才五格起名起名法大气的投资公司起名孙氏男婴儿起名采购流程意大利冰淇淋加盟店童姓起姓名男女宝宝起名一个勺子下载元宵节祝福姓汐的女孩起名瓷都免费取名网好名堂宝宝起名大师用诗经当中的字给女孩起名字做了无痛胃镜后很后悔盘锦水游城皇家骑士团:命运之轮少年生前被连续抽血16次?多部门介入两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”淀粉肠小王子日销售额涨超10倍高中生被打伤下体休学 邯郸通报单亲妈妈陷入热恋 14岁儿子报警何赛飞追着代拍打雅江山火三名扑火人员牺牲系谣言张家界的山上“长”满了韩国人?男孩8年未见母亲被告知被遗忘中国拥有亿元资产的家庭达13.3万户19岁小伙救下5人后溺亡 多方发声315晚会后胖东来又人满为患了张立群任西安交通大学校长“重生之我在北大当嫡校长”男子被猫抓伤后确诊“猫抓病”测试车高速逃费 小米:已补缴周杰伦一审败诉网易网友洛杉矶偶遇贾玲今日春分倪萍分享减重40斤方法七年后宇文玥被薅头发捞上岸许家印被限制高消费萧美琴窜访捷克 外交部回应联合利华开始重组专访95后高颜值猪保姆胖东来员工每周单休无小长假男子被流浪猫绊倒 投喂者赔24万小米汽车超级工厂正式揭幕黑马情侣提车了西双版纳热带植物园回应蜉蝣大爆发当地回应沈阳致3死车祸车主疑毒驾恒大被罚41.75亿到底怎么缴妈妈回应孩子在校撞护栏坠楼外国人感慨凌晨的中国很安全杨倩无缘巴黎奥运校方回应护栏损坏小学生课间坠楼房客欠租失踪 房东直发愁专家建议不必谈骨泥色变王树国卸任西安交大校长 师生送别手机成瘾是影响睡眠质量重要因素国产伟哥去年销售近13亿阿根廷将发行1万与2万面值的纸币兔狲“狲大娘”因病死亡遭遇山火的松茸之乡“开封王婆”爆火:促成四五十对奥巴马现身唐宁街 黑色着装引猜测考生莫言也上北大硕士复试名单了德国打算提及普京时仅用姓名天水麻辣烫把捣辣椒大爷累坏了

两个鬼故事 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化