Java 8之Map新增方法<转>
在Java 8中的Map.Entry接口中增加了comparingByKey, comparingByValue方法,它们都返回Comparator<Map.Entry<K,V>>, Comparator是一个函数接口,主要是方便Lambda表达式的使用。
在Java 8中的Map接口增加了一些default方法,提升了对key, value操作的便利性。下面是基本数据的定义,通过这些数据说明新增的一些方法。
1 |
Map<Integer, String> map = new HashMap<>(); |
getOrDefault 方法
如果指定的key存在,则返回该key对应的value,如果不存在,则返回指定的值。例子如下
1 |
// key为4不存在,输出 d |
forEach 方法
遍历Map中的所有Entry, 对key, value进行处理, 接收参数 (K, V) -> void, 例子如下
1 |
// 输出1a, 2b, 3c |
replaceAll 方法
替换Map中所有Entry的value值,这个值由旧的key和value计算得出,接收参数 (K, V) -> V, 类似如下代码
1 |
for (Map.Entry<K, V> entry : map.entrySet()) |
例如如下:
1 |
map.replaceAll((key, value) -> (key + 1) + value); |
putIfAbsent 方法
如果key关联的value不存在,则关联新的value值,返回key关联的旧的值,类似如下代码
1 |
V v = map.get(key); |
示例代码如下:
1 |
map.putIfAbsent(3, "d"); |
remove 方法
接收2个参数,key和value,如果key关联的value值与指定的value值相等(equals),则删除这个元素,类似代码如下:
1 |
if (map.containsKey(key) && Objects.equals(map.get(key), value)) {
|
示例代码如下:
1 |
map.remove(1, "b"); |
replace(K key, V oldValue, V newValue) 方法
如果key关联的值与指定的oldValue的值相等,则替换成新的newValue,类似代码如下:
1 |
if (map.containsKey(key) && Objects.equals(map.get(key), value)) {
|
示例代码如下
1 |
map.replace(3, "a", "z"); |
replace(K key, V value) 方法
如果map中存在key,则替换成value值,否则返回null, 类似代码如下:
1 |
if (map.containsKey(key)) {
|
示例代码如下:
1 |
// 输出旧的值, a |
computeIfAbsent 方法
如果指定的key不存在,则通过指定的K -> V计算出新的值设置为key的值,类似代码如下:
1 |
if (map.get(key) == null) {
|
示例代码如下:
1 |
map.computeIfAbsent(1, key -> key + " computed"); |
computeIfPresent 方法
如果指定的key存在,则根据旧的key和value计算新的值newValue, 如果newValue不为null,则设置key新的值为newValue, 如果newValue为null, 则删除该key的值,类似代码如下:
1 |
if (map.get(key) != null) {
|
示例代码如下:
1 |
map.computeIfPresent(1, (key, value) -> (key + 1) + value); |
compute 方法
compute方法是computeIfAbsent与computeIfPresent的综合体。
merge(K key, V value, BiFunction<? super V, ? super V, ? extends V> remappingFunction) 方法
如果指定的key不存在,则设置指定的value值,否则根据key的旧的值oldvalue,value计算出新的值newValue, 如果newValue为null, 则删除该key,否则设置key的新值newValue。类似如下代码:
1 |
V oldValue = map.get(key); |
示例代码如下:
1 |
// 存在key为1, 输出 a merge |
Java 8之Map新增方法<转>的更多相关文章
- Java中迭代Map的方法
Map<String, String> mapServlet = new HashMap<String, String>(); System.out.println(" ...
- Java compiler level does not match the version of the installed Java project facet. map解决方法
右键项目"Properties",在弹出的"Properties"窗口左侧,单击"Project Facets",打开"Proje ...
- 谈谈java中遍历Map的几种方法
java中的map遍历有多种方法,从最早的Iterator,到java5支持的foreach,再到java8 Lambda,让我们一起来看下具体的用法以及各自的优缺点 先初始化一个map public ...
- java中遍历Map几种方法
java中的map遍历有多种方法,从最早的Iterator,到java5支持的foreach,再到java8 Lambda,让我们一起来看下具体的用法以及各自的优缺点. 先初始化一个map: publ ...
- jdk8中map新增的merge方法介绍
1.Map.merge方法介绍 jdk8对于许多常用的类都扩展了一些面向函数,lambda表达式,方法引用的功能,使得java面向函数编程更为方便.其中Map.merge方法就是其中一个,merge方 ...
- Java中遍历Map集合的四种方法
在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...
- Java中遍历Map的几种方法
转自: http://blog.csdn.net/wzb56/article/details/7864911 方法分为两类: 一类是基于map的Entry:map.entrySet(); 一类是基 ...
- java中遍历map对象的多种方法
在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有ma ...
- java中遍历MAP,嵌套map的几种方法
java中遍历MAP的几种方法 Map<String,String> map=new HashMap<String,String>(); map.put("us ...
随机推荐
- python正则表达式(4)--search方法
1.re.search函数 re.search 扫描整个字符串并返回第一个成功的匹配,如果匹配失败search()就返回None. (1)函数语法: re.search(pattern, string ...
- js--获取和设置css属性
在这一章我们讲述一下如何通过js来操作css中的属性 1,首先,我们想获取元素的一些属性.例如innerHTML,value等值时,我们可以 var object=document.getELemen ...
- Linux下如何退出vim的一些常用命令总结
1.保存并退出 linux下安装好了vim以及gcc后,我们开始新建一个c文件,例如: vim test.c 之后进入vim的编辑框中,点击i进入插入模式,开始编辑程序,当你编写好自己的程序之后,按E ...
- 201671030104 邓海祥 实验十四 团队项目评审&课程项目总结
项目 内容 课程名称 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验十四 团队项目评审&课程学习总结 课程学习目标 (1)掌握软件项目评审会流程:(2)反思 ...
- runloop是一个系统架构、是一个系统
信号与系统的系统: 事件源.派发系统.事件传播链.事件处理函数: 等组成的整体: 强调的重点是联系与结合.
- Simple Redux
This is a post that tries to explain the the basics of Redux. We’ll build a minimal working example ...
- C++编译器与链接器工作原理
http://blog.csdn.net/success041000/article/details/6714195 1. 几个概念 1)编译:把源文件中的源代码翻译成机器语言,保存到目标文件中.如果 ...
- POJ3616-Milking Time-(dp)
题意:牛有m个时间段可以挤奶,每个时间段的开始时间,结束时间,挤奶量不尽相同,寄完一次需要休息r时间,求在n时间内如何安排牛挤奶产量最大. 解题: 1.休息r时间,当做结束时间需要+r 2.以结束时间 ...
- v熬夜是场可怕的自杀
转载于 https://baike.baidu.com/vbaike/%E7%86%AC%E5%A4%9C%E6%98%AF%E5%9C%BA%E5%8F%AF%E6%80%95%E7%9A%84%E ...
- fpm 打包跨平台rpm 包的一个问题
平时我们开发机器可能使用的是mac 系统,但是部署机器kennel是linux,默认会有一个操作系统的问题, 我们可以在打包的时候指定os版本信息 参考 --rpm-os linux 参考例子 一个构 ...