JAVA集合知识点汇总<二> Set集合

一、Set接口

1.父接口 Collection

2.特点 唯一 无序(插入顺序跟遍历顺序不一致,没下标)

唯一:Set集合中不允许出现重复的元素,如果向Set集合中存储重复的元素是无效的,但不会报错

无序:Set集合不会维护集合中元素的插入顺序,即不存在下标或索引

3.Set接口中的功能方法 (Set接口中没有自有方法,全部继承自Collection接口)

4.凡是带有下标的方法都不支持

二、HashSet

1.数据结构(散列表) 线程不安全 HashSet采用哈希(散列)数据结构来存储对象,大大提高查询效率

2.构造方法

3.通过代码证明Set集合都是唯一 无序

4.添加重复数据时不会报错,而是无效

5.当使用该集合存储自定义类型的数据时,要求必须重写hashCode和equals方法

在添加新数据的时候,先判断hashCode,不相等就添加;如果相等则判断equals,不相等就添加

三、LinkedHashSet

1.它跟HashSet一样,也是无序、唯一的,不保证线程安全

2.功能性方法也都一样

3.维护插入顺序作为遍历顺序(仍然没有索引或下标)

多了一个链表用来维护插入顺序作为遍历顺序(仍然没有索引或下标)

四、TreeSet类

1.数据结构(平衡二叉树) 线程不安全 效率 优缺点

2.构造方法

3.它也是保证唯一性,同时可以对数据进行“自然排序”,仍然没有下标

4.它有几个特有的方法,其他方法跟HashSet一样

public Object ceiling(Object e)
public Object floor(Object e)
public Object first()
public Object last()
public Object higher(Object e)
public Object lower(Object e)

五、遍历方法for和foreach

1.for循环 一般控制下标 只适合有下标的数组或集合,比如set没有下标,就无法使用for循环遍历

2.对于没有下标的集合(如set),需要用foreach循环,foreach可用于数组,可用于List,也可以用于Set

3.foreach其实是借助于迭代器实现遍历的,Java编译器在编译代码的过程中,会把foreach代码转化为迭代器代码(可以查看字节码文件)。

六、迭代器写法

1.把集合中的数据当成一个一个景点

2.逛所有的景点就是遍历

3.需要一个导游(迭代器) Iterator<跟集合一致> it=集合对象.iterator();

4.while(it.hasNext())
{
it.next();
}

七、迭代器设计模式实现原理

1.设计模式

2.两个接口+一个内部类
结构图

3.JDK5以前是没有foreach循环,程序员在遍历没下标的集合时必须写迭代器代码

4.JDK5以后为了让程序员在遍历没下标的集合时更加方便,提供foreach循环

5.程序员写的是foreach循环,但是编译后都替换为迭代器代码

6.实际开发时还是要使用foreach循环的

八、并发修改异常

1.在遍历一个集合时,如果需要删除一个数据,那么会容易出现并发修改异常

2.谁遍历,就让谁删除(例如在遍历Set的时候不允许删除Set(迭代器是单独一个线程,涉及到数据同步的问题),可以通过迭代器的remove方法来解决)

3.就必须使用原始的迭代器代码

九、Collection集合应用场景

1.判断要存储的数据是否有唯一性要求

2.判断要存储的数据是否有顺序要求

3.判断功能上是查询多些还是插入、删除多些?

4.判断功能上是否对线程安全有要求?

项目地址:传送门

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • Java集合类可用于存储数量不等的对象,并可以实现常用的数据结构如栈,队列等,Java集合还可以用于保存具有映射关...
    小徐andorid阅读 1,915评论 0 13
  • java基础 集合承继包含图 Collection vs Collections 首先,"Collection" ...
    onlyHalfSoul阅读 1,295评论 0 5
  • 集合 集合与数组 数组(可以存储基本数据类型)是用来存现对象的一种容器,但是数组的长度固定,不适合在对象数量未知的...
    手打小黑板阅读 349评论 0 0
  • 四、集合框架 1:String类:字符串(重点) (1)多个字符组成的一个序列,叫字符串。生活中很多数据的描述都采...
    佘大将军阅读 732评论 0 2
  • 原文地址 Java集合 Java集合框架:是一种工具类,就像是一个容器可以存储任意数量的具有共同属性的对象。 Ja...
    gyl_coder阅读 973评论 0 8