java集合知识点总结
下面是java中常见的集合:
List--列表:内部元素有序,可以重复,
ArrayList:线程不安全,效率高。数据结构是线性表,底层结构是顺序表,也就是数组,有唯一的下标来指定元素的位置,查询快,增删慢。
Vector:类似于ArrayList,但是线程安全,代价就是效率低。完全可以用ArrayList来替代,
List<String> list = Collections.synchronizedList(new ArrayList<String>())
上面代码就是将ArrayList改为线程安全的,其余的操作基本和原本一样。
LinkedList:线程不安全,效率高。数据结构是线性表,底层结构是单链表,查询慢,但是增删快
Set--集合:内部元素无序,不可重复
HashSet:线程不安全,效率高。数据结构是哈希表,底层结构是顺序表,LinkedHashSet的底层结构是单链表,具体类比ArrayList,
TreeSet:线程不安全,效率高。数据结构是红黑树,和HashSet的区别在于,它的元素是有序的,而这里的有序和我们在List谈到的有序不是一个意思,List中的有序是指你输入["gol","long","xiao"],在存储的时候下标0对应的就是"gol",下标1对应的就是"long",而这里的有序指的是元素在存储时自己遵守的一套规则,因为本身元素是不可重复的,和我们的添加顺序没有关系,比如我们输入[3,2,1],在存储是就会变为[1,2,3],按照1,2,3这个规则来排序,如果想得到类似于list的那种有序,LinkedHashSet可以实现。
Map--字典:通过“键”寻找“值”
HashMap:线程不安全,效率高。数据结构是哈希表,底层结构是顺序表,LinkedHashMap的底层结构是单链表,具体类比ArrayList
TreeMap:线程不安全,效率高。数据结构是红黑树,可以存储 null 值
HashTable:线程安全,效率低。数据结构是哈希表,不能存储 null 值
迭代器(iterator)遍历
list可以通过索引取值遍历,map可以通过键值,那set要怎么遍历呢?其实map的键的集合就是一个set,我们不处理怎么遍历set的问题就无法查看set和map中的值了,于是就有了迭代器
HashSet set = new HashSet<>();
set.add(99);
set.add(100);
set.add("gol");
Iterator it = set.iterator();
while (it.hasNext()){
System.out.println(it.next());
}
迭代器就是一种提取集合中数据的接口,我们只需要对集合调用iterator()方法生成一个迭代器集合,而其内部如何生成对我们隐藏了,在迭代器中修改原集合的会触发ConcurrentModificationException(并发修改异常),也就是说在迭代器中不要进行修改(修改元素的值可以的,只要没有改变原集合的长度)的操作,会出错。若想在迭代的时候修改长度,List集合特有的listIterator()方法可以实现,(但仅仅是List有此方法)
而增强for循环就是在底层封装了迭代器,所有同样存在并发修改异常
HashSet<Integer> set = new HashSet<>();
set.add(99);
set.add(100);
set.add(98);for (Integer s:set){
System.out.println(s);
}
java集合知识点总结的更多相关文章
- java集合知识点
若不重写equals方法,则调用的是object对象的equals方法,相当于==比较,比较的是对象的内存地址 |------Collection接口:单列集合,用来存储一个一个对象 |------L ...
- Java最重要的21个技术点和知识点之JAVA集合框架、异常类、IO
(三)Java最重要的21个技术点和知识点之JAVA集合框架.异常类.IO 写这篇文章的目的是想总结一下自己这么多年JAVA培训的一些心得体会,主要是和一些java基础知识点相关的,所以也希望能分享 ...
- Java集合总结【面试题+脑图】,将知识点一网打尽!
前言 声明,本文用的是jdk1.8 花了一个星期,把Java容器核心的知识过了一遍,感觉集合已经无所畏惧了!!(哈哈哈....),现在来总结一下吧~~ 回顾目录: Collection总览 List集 ...
- 知识点:Java 集合框架图
知识点:Java 集合框架图 总结:Java 集合进阶精讲1 总结:Java 集合进阶精讲2-ArrayList Java集合框架图 我们经常使用的Arrayist.LinkedList继承的关系挺复 ...
- Java 集合常见知识点&面试题总结(上),2022 最新版!
你好,我是 Guide.秋招即将到来(提前批已经开始),我对 JavaGuide 的内容进行了重构完善,公众号同步一下最新更新,希望能够帮助你. 你也可以在网站(javaguide.cn)上在线阅读, ...
- Java集合原理分析和知识点大杂烩(多图初学者必备!!)
一.数据结构 数据结构就是计算机存储.组织数据的方式. 在计算机科学中,算法的时间复杂度是一个函数,它定性描述了该算法的运行时间,常用O符号来表述. 时间复杂度是同一问题可用不同算法解决, ...
- java后端知识点梳理——java集合
集合概览 Java中的集合,从上层接口上看分为了两类,Map和Collection.Map是和Collection并列的集合上层接口,没有继承关系. Java中的常见集合可以概括如下. Map接口和C ...
- 【集合框架】Java集合框架综述
一.前言 现笔者打算做关于Java集合框架的教程,具体是打算分析Java源码,因为平时在写程序的过程中用Java集合特别频繁,但是对于里面一些具体的原理还没有进行很好的梳理,所以拟从源码的角度去熟悉梳 ...
- Java集合框架中Map接口的使用
在我们常用的Java集合框架接口中,除了前面说过的Collection接口以及他的根接口List接口和Set接口的使用,Map接口也是一个经常使用的接口,和Collection接口不同,Map接口并不 ...
随机推荐
- WPF中使用Hashtable剔除重复字符串(比如电话号码)
原文:WPF中使用Hashtable剔除重复字符串(比如电话号码) 本文中的输入框中的字符串是逗号隔开的,你可以换成其他特别的字符串.本篇中的亮点:1. 里面有一个玻璃样式按钮,用XAML制作2. W ...
- 【树转数组】poj1195
/* 二维的树状数组: 更新某个元素时: NO.1:c[n1],c[n2],c[n3],....,c[nm]; 当中n1 = i,n(i+1) = ni+lowbit(ni); nm+lowbit(n ...
- Swift 中使用 SwiftyJSON 制作一个比特币价格 APP
Swift 中处理 JSON 数据有很多种方式,可以使用原生的 NSJSONSerialization,也可以使用很多第三方库.原生的 NSJSONSerialization 方式这篇文章中介绍过.这 ...
- Bootstrap 屏幕类型
/* 超小屏幕(手机,小于 768px) */ /* 没有任何媒体查询相关的代码,因为这在 Bootstrap 中是默认的(还记得 Bootstrap 是移动设备优先的吗?) */ /* 小屏幕(平板 ...
- 通过.NET客户端调用Web API(C#)
3.2 Calling a Web API From a .NET Client (C#) 3.2 通过.NET客户端调用Web API(C#) 本文引自:http://www.asp.net/web ...
- ntp时间同步,各种配置方法
1 Windows xp NTP服务器的配置(2003配置方式一样) 1) 首先需要关闭作为NTP服务器的windows系统自带的防火墙,否则将同步不成功. 2) 单击“开始”,单击“运行”,键入 r ...
- passed into methods by value java专题
java没有引用传递只有按值传递,没有引用传递只有按值传递,值传递.因为Primitive类型的值不能改变,所以method不能更改调用方传的primitive 值.因为method更改的是Primi ...
- JavaScript 中的12种循环遍历方法
原文:JavaScript 中的12种循环遍历方法 题目:请介绍 JavaScript 中有哪些循环和遍历的方法,说说它们的应用场景和优缺点? 1.for 循环 let arr = [1,2,3];f ...
- Qt MVC设计模式(五篇)
http://blog.csdn.net/qq_19672579/article/details/46952675http://blog.csdn.net/qq_19672579/article/de ...
- 图像滤镜艺术---(Lightleaks Filter)漏光滤镜
原文:图像滤镜艺术---(Lightleaks Filter)漏光滤镜 (Lightleaks Filter)漏光滤镜 漏光拍摄其实就是一种摄影手法,最初是因为强烈光照导致相片交卷的过分曝光,最终在成 ...