四种常见的数据结构、LinkedList、Set集合、Collection、Map总结
四种常见的数据结构:
1.堆栈结构:
先进后出的特点。(就像弹夹一样,先进去的在后进去的低下。)
2.队列结构:
先进先出的特点。(就像安检一样,先进去的先出来)
3.数组结构:
查找元素快,但是增删元素慢
4.链表结构:
增删元素快,但是查找元素慢
LinkedList:(List接口下的一个子类,和ArrayList是同级别关系)
1.底层是链表结构
2.它的一些特有方法:
addFirst(E e) : 向集合中的开头添加元素
addLast(E e):向集合的末尾添加元素
getFirst():得到集合中的第一个元素
getLast():得到集合中的最后一个元素
removeFirst():删除集合中的第一个元素
removeLast():删除集合中的最后一个元素
pop(E e) : 从集合的最上面弹出一个元素
push():向集合的最上面添加元素
isEmpty() : 判断集合中是否有为空
3.在开发时,LinkedList集合也可以作为堆栈,队列的结构使用。在开发时,LinkedList集合也可以作为堆栈,队列的结构使用。
使用的方法是:调用addFirst(E e) 方法和getFirst() 方法
Set集合(Set是一个接口,和List一样,它俩也是同级别关系)
Set集合的遍历方式只有两种,1. 增强for 2. 迭代器
Set集合特点:
唯一性,元素不重复
1.Set的子类有:
HashSet、LinkedHashSet
2.HashSet:
a.HashSet是无序的,存取顺序不一样
b.底层是哈希表结构,通常自定义对象是需要重写HashCode方法和equals方法
c.HashSet是使用HashCode方法和equals方法来保证元素唯一的
d.判断原理是:
先判断HashCode方法
相同:
不添加
不相同:判断equals方法:
不相同:添加
相同:不添加
LinkedHashSet:
1.LinkedHashSet是有序的,存取顺序是一样的
2.底层是链表+哈希表结构。
3.通过链表来保证有序。通过哈希表来保证元素的唯一。
Collection总结:
1.子类:
List、Set(两个都是接口)
List子类:
ArrayList
LinkedList
Set子类:
HashSet
LinkedHashSet
2.Collection的方法:
boolean add(Object e): 添加
void clear(): 清空
boolean remove(Object o):删除
boolean contains(Object o): 包含
boolean isEmpty():是否为空
Iterator iterator():迭代器
int size(): 集合长度
Object toArray(): 将集合存到数组中
3.迭代器:
两个方法:
hasNext():是否有下一个元素
next(): 获取下一个元素
4.List和Set的区别:
List:
有序,且可有重复元素
Set:
它是一个无序的集合(元素存与取的顺序可能不同)
不可以有重复的元素
5.List集合中的特有方法:(有角标的都是List集合中的)
void add(int index, Object element) 将指定的元素,添加到该集合中的指定位置上
Object get(int index) 返回集合中指定位置的元素。
Object remove(int index) 移除列表中指定位置的元素, 返回的是被移除的元素
Object set(int index, Object element) 用指定元素替换集合中指定位置的元素,返回值的更新前的元素
6.泛型:
好处:
提高了程序的安全性
将运行时期的异常提到的编译时期
避免了类型转换
Map:(它也是一个接口,它是和Collection同级别的,它是一个双列集合)
常用子类:
HashMap<key , value>:
泛型里存储键和值,键唯一,但是值可以重复。底层是哈希表结构,基本和HashSet集合差不多,在存储自定义对象时,需要重写HashCode方法和equals方法。无序。
LinkedHashMap:
底层是链表+哈希表结构。有序,存和取的顺序一致。
方法:
put(K,V):添加元素,相当于list集合中的add方法
get(key):得到key对应的值。
Map遍历(两种方式)
1. keySet()方法
转为Set对象,获取Map集合中的键集,存储到Set集合中
然后可使用增强for或迭代器来获取键和值都通过,键来获取值。
2. entrySet()方法
方法:
getey()
getValue()
转为entry对象,获取Map集合中的键和值的映射关系,存储到entry对象中。
然后,可以使用增强for或迭代器来获取键和值。
都通过,键来获取值。
Properties类(一般和流一块使用,它也是Map下的一个子类它是一个可以持久化的属性集。键值可以存储到集合中,也可以存储到持久化的设备(硬盘、U盘、光盘)上。键值的来源也可以是持久化的设备。
(有和流技术相结合的方法。)
1.public Object setProperty(String key, String value)调用 Map 的方法 put。
2.public Set<String> stringPropertyNames()返回此属性列表中的键集, //keyset()方法
3.public String getProperty(String key)用指定的键在此属性列表中搜索属性//get()方法
写入文件的方法:
store(Writer,”文件的描述信息”)
读取文件的方法:
load(Reader)
可变参数:
表现格式为:
数据类型... 变量名
相当于一个数组。
Collections工具类
方法
shuff()随机打乱方法
sort()排序方法,按照自然规律排序。
四种常见的数据结构、LinkedList、Set集合、Collection、Map总结的更多相关文章
- 一文读懂四种常见的XML解析技术
之前的文章我们讲解了<XML系列教程之Schema技术_上海尚学堂java培训技术干货><XML的概念.特点与作用.XML申明_上海Java培训技术干货>,大家可以点击回顾一下 ...
- 四种常见的App弹窗设计,你有仔细注意观察吗?
弹窗又称为对话框,是App与用户进行交互的常见方式之一.弹窗分为模态弹窗和非模态弹窗两种,两者的区别在于需不需要用户对其进行回应.模态弹窗会打断用户的正常操作,要求用户必须对其进行回应,否则不能继续其 ...
- (转)四种常见的 POST 提交数据方式
四种常见的 POST 提交数据方式(转自:https://imququ.com/post/four-ways-to-post-data-in-http.html) HTTP/1.1 协议规定的 HTT ...
- 四种常见的提示弹出框(success,warning,error,loading)原生JavaScript和jQuery分别实现
原文:四种常见的提示弹出框(success,warning,error,loading)原生JavaScript和jQuery分别实现 虽然说现在官方的自带插件已经有很多了,但是有时候往往不能满足我们 ...
- 四种常见的 POST 提交数据方式(application/x-www-form-urlencoded,multipart/form-data,application/json,text/xml)
四种常见的 POST 提交数据方式(application/x-www-form-urlencoded,multipart/form-data,application/json,text/xml) 转 ...
- application/json 四种常见的 POST 提交数据方式
四种常见的 POST 提交数据方式 HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS.GET.HEAD.POST.PUT.DELETE.TRACE.CONNECT 这几种.其中 ...
- 转:application/json 四种常见的 POST 提交数据方式
四种常见的 POST 提交数据方式 HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS.GET.HEAD.POST.PUT.DELETE.TRACE.CONNECT 这几种.其中 PO ...
- POST提交数据时四种常见的数据格式
最近项目部署到新环境tomcat+mysql,想看看项目部署成功没有,就用soupui调对应接口开测试,soupui使用比较简单,给上接口地址,入参xml报文,把入参的media Type设置为app ...
- http协议里定义的四种常见数据的post方法
原文 https://blog.csdn.net/charlene0824/article/details/51199292 关于http协议里定义的四种常见数据的post方法,分别是: applic ...
随机推荐
- HTML 5的革新——语义化标签(一)
HTML 5的革新之一:语义化标签一节元素标签. 在HTML 5出来之前,我们用div来表示页面章节,但是这些div都没有实际意义.(即使我们用css样式的id和class形容这块内容的意义).这些标 ...
- python面试的100题(7)
8.将字符串 "k:1 |k1:2|k2:3|k3:4",处理成字典 {k:1,k1:2,...} str1 = "k:1|k1:2|k2:3|k3:4" de ...
- 关于memset....我太难了
众所周知memset是个清空数组的好东西 然而...它慢的要死 直接让我从30ms炸到1045ms 于是快乐tle .... 是我的错 所以以后还是手动清空 (我真快乐)
- tianmao项目的学习笔记
1.后台-分类管理/查询 实体相关的知识: 1.1@Entity和@Table的区别:https://www.cnblogs.com/softidea/p/6216722.html 1.2@JsonI ...
- HTML学习(6)段落
HTML段落使用<p>标签定义,浏览器会自动地在段落的前后添加空行. 如果不希望产生空行,可以使用<br />换行标签. 在元素内容中,连续的空格会被浏览器认格式化为一个空格, ...
- 每天进步一点点------CRC码的FPGA实现
一.CRC码的FPGA实现之一CRC的原理 实验目的 学习用FPGA设计一个数据通信中常用的数据检错模块——循环冗余检验CRC模块,熟悉理解CRC的检错原理. 实验原理 循环冗余检验(CRC)算法原理 ...
- vue-cli 3 脚手架搭建(create)
地址:https://cli.vuejs.org/zh/guide/ 安装步骤: 提示:node 版本要 8.9+ 两种方式: (1) npm install -g @vue/cli (2) yarn ...
- C++ split分割字符串函数
将字符串绑定到输入流istringstream,然后使用getline的第三个参数,自定义使用什么符号进行分割就可以了. #include <iostream> #include < ...
- jQuery 源码解析(三十) 动画模块 $.animate()详解
jQuery的动画模块提供了包括隐藏显示动画.渐显渐隐动画.滑入划出动画,同时还支持构造复杂自定义动画,动画模块用到了之前讲解过的很多其它很多模块,例如队列.事件等等, $.animate()的用法如 ...
- 忘记win8开机密码的清除方法
1.进PE 2.打开计算机,进入 C:\Windows\System32 目录下 3.找到 magnify.exe 改名为 mangify1.exe .将 cmd.exe 改名为 magnify.ex ...