12.Maps
1 Maps
1.1 Map声明和访问
maps中的元素是key-value对儿,key与value之间使用冒号(:)分割。创建一个空value的map,使用[:]。默认情况下,map的类型是java.util.HashMap。如果这些keys是String类型的,那么你可以不使用单引号或双引号括起来。
但是,如果使用变量作为key,需要将key用()括起来。
重新赋值map中的指定value,使用map[key]=value。
访问该map中的value,使用map[key];还可以使用get(key) or get(key,default)。在get(key,default)中,如果key不存在,返回的是default,同时,该(key,default)会增加到该map中。
|
package map /** * 声明和访问map * @author zuoys * */ class DeclareAndAccess { static main(args) { //创建一个有值的map def map = ["Jim":"Knopf","Thomas":"Edison"]; //点(.)操作符被重载来访问该value map.AnotherKey = "Testing"; //创建没加引号的keys def anotherMap = [Jim:"Knopf",Thomas:"Edison"]; //.size():map中元素的数量 assert anotherMap.size()==2; //key可以使用变量,但必须使用括号括起来,否则默认是"x",因为key可以不使用引号。 def x = "a"; //以下返回false,因为x可以不使用引号,因此认为是"x" println ([a:1]==[x:1]); //以下返回true println ([a:1]==[(x):1]); //创建一个空的map def emptyMap = [:] println("===============set/get"); println (map.get("Jim")) //重新设置value map["Jim"]="左运松"; //获取map中指定value println (map["Jim"]); println (map.get("Jim")); println (map.get("zuoys", "遥远2"));//map中没有zuoys,返回 遥远2,并新增zuoys:遥远2 println (map.get("zuoys"))//再次获取zuoys,获取到的是 遥远2 println("===============keySet()"); Set sets = map.keySet(); if (!sets.isEmpty()) { Iterator iterator = sets.iterator(); while (iterator.hasNext()) { String i = iterator.next(); println(i); } } } } |
输出
keySet()方法返回所有的keys,不重复的元素且没有顺序的。
1.2 遍历及是否包含
操作元素,可以使用闭包,基于each(), any() and every()方法。
each()返回T,遍历每个元素;any()和every()返回符合闭包中条件的Boolean。
|
package map import java.beans.WeakIdentityMap.Entry; class EachAnyEveryMethod { static main(args) { def mymap = [1:"左1",2:"左2",3:"左23"]; println("=======each,遍历每个元素,并验证每个key是否大于1") mymap.each { entry -> println(entry.key > 1)}; println("=======each,遍历每个元素,并验证每个value是否包含 2") mymap.each { entry -> println(entry.value.contains("2"))}; println "=======any,任何一个:" //验证 map中任何一个value,哪怕有一个value包含【左】都返回true,否则返回false println mymap.any {entry -> entry.value.contains("左")}; println "=======every,每一个"; /** * 验证 map中每一个的key的大小都要小于3,才返回true,否则哪怕有一个不小于3都返回false * 如果小于4,则输出true */ println mymap.every{ entry -> entry.key < 3}; println("=============使用keySet()遍历map"); def result = ''; for (key in mymap.keySet()) { result += key; } println (result); println("=============使用each{}遍历map"); mymap.each { key, value -> print key + " "; println value; }; println("=============使用each{}遍历map"); mymap.each { entry -> print entry.key +" "; println entry.value; }; } } |
输出
each{},中的参数:
可以是entry(完整的一条元素【含key,value】,entry可以起任意名字,因为只是参数而已)。
也可以是key,value(可以起任意名字,因为只是参数而已)。
1.3 搜索map
能够使用下边的方法搜索map:
- findAll(closure) – 找到符合闭包条件的所有元素
- find(closure) – 找到符合闭包条件的第一条元素。
- collect(closure) – 返回符合闭包条件的所有元素,其类型是list。
- submap('key1', 'key2',) – 返回含有key1,key2元素的map.
1.4 方法调用时使用命名参数
在方法调用时,可能会用到命名参数。
|
package map.namedarguments class Address { String street, city; } |
|
package map.namedarguments class Person { String name; Address address; String phoneNumber; def moveToNewPlace(inputAsMap,newPhoneNumber) { address.street = inputAsMap.street; address.city = inputAsMap.city; phoneNumber = newPhoneNumber; } } |
|
package map.namedarguments class NamedArguments { static main(args) { def address = new Address(street:"开发区大街",city:"燕郊"); def p = new Person(name:"zuo",address:address,phoneNumber:"18600000000"); assert "zuo" == p.name; assert "18600000000" == p.phoneNumber; assert "开发区大街" == p.address.street; assert "燕郊" == p.address.city; /** * 下边会自动转换为 * [street:"北三环中路",city:"北京"],"15699999999"。其实用此种方式是最好的。 */ p.moveToNewPlace(street:"北三环中路", "15699999999",city:"北京"); assert "zuo" == p.name; assert "15699999999" == p.phoneNumber; assert "北三环中路" == p.address.street; assert "北京" == p.address.city; } } |
所有的命名参数都会被groovy转换为一个map,并且传递到被调用的方法的第一个参数中。剩下的所有参数会被传递到其后的参数中。传递进去后,该方法从map中提取相应的参数。
1.5 list 转 map
使用collectEntries 方法将list转换为map。
|
package map class List2Map { static main(args) { def words = ['a','b','ac','d']; //简单的转换,必须使用it def result = words.collectEntries { [(it):0] } assert result.size() == 4; assert result.a == 0; //下边使用闭包检索包含'a'的元素 def map = words.collectEntries() { [(it):it.contains('a')]; } println map; assert map.a && map.ac && !map.b && !map.d } } |
输出
|
[a:true, b:false, ac:true, d:false] |
contains方法,返回的value是Boolean。
12.Maps的更多相关文章
- [Erlang 0117] 当我们谈论Erlang Maps时,我们谈论什么 Part 2
声明:本文讨论的Erlang Maps是基于17.0-rc2,时间2014-3-4.后续Maps可能会出现语法或函数API上的有所调整,特此说明. 前情提要: [Erlang 0116] 当我们谈论E ...
- (转)Linux core 文件介绍与处理
1. core文件的简单介绍 在一个程序崩溃时,它一般会在指定目录下生成一个core文件.core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的. 2. 开启或关闭core文件的生成用以 ...
- SpringBoot之旅第二篇-配置
一.引言 虽然springboot帮我们进行了自动配置,但配置还是不可避免的,比如最简单的端口号,数据库连接.但springboot的配置一般不用xml进行配置,而是yml和properties,选择 ...
- java开发注解总结笔记
目录 1.最基础注解(spring-context包下的org.springframework.stereotype) 1.1.@Controller @Service @Repository @Co ...
- springboot 配置文件
– Spring Boot使用一个全局的配置文件 • application.properties • application.yml – 配置文件放在src/main/resources目录或者类路 ...
- SpringBoot配置(1) 配置文件application&yml
SpringBoot配置(1) 配置文件application&yml 一.配置文件 1.1 配置文件 SpringBoot使用一个全局的配置文件,配置文件名是固定的. application ...
- 尚硅谷【SpringBoot】入门
https://www.bilibili.com/video/av20965295/?p=2 缺点: 基于springframe的封装 对framework api需要熟悉 2微服务 2014 ...
- 尚硅谷springboot学习9-配置文件值注入
首先让我想到的是spring的依赖注入,这里我们可以将yaml或者properties配置文件中的值注入到java bean中 配置文件 person: lastName: hello age: 18 ...
- Elasticsearch系列(五)----JAVA客户端之TransportClient操作详解
Elasticsearch JAVA操作有三种客户端: 1.TransportClient 2.JestClient 3.RestClient 还有种是2.3中有的NodeClient,在5.5.1中 ...
随机推荐
- 青岛理工ACM交流赛 J题 数格子算面积
数格子算面积 Time Limit: 1000MS Memory limit: 262144K 题目描述 给你一个多边形(用’\’和’/’表示多边形的边),求多边形的面积. 输入 第一行两个正整数h ...
- Python:元组
元组:只读,不能修改,使用小括号 创建元组: tup1 = ('physics', 'chemistry', 1997, 2000) tup2 = (1, 2, 3, 4, 5 ) tup3 = &q ...
- SDOI2017 Round1 Day1 题解
不知道有几个AK的,除了出题人SB搬了个BZOJ3779以外,应该没什么因素阻碍AK吧.要是SCOI考这套题多好. BZOJ4816 数字表格 SB反演,推出答案为$\prod_{i=1}^nf^{\ ...
- POJ1226(strstr)
Substrings Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 13348 Accepted: 4722 Descr ...
- bzoj2117
动态电分治+二分 肯定要枚举所有点对,那么我们建出点分树降低树高,然后每个点存下点分树中所有子树到这个点的距离,然后二分+lower_bound就行了. #include<bits/stdc++ ...
- 高级java工程师面试题-随笔
最近打算要换工作,也面试了几家,因为不是自己喜欢的所以拒了一些(当然也有人家不要我的.....).在面试的过程中发现对java高级程序员的考察基本上围绕知识面,知识深度两个方面来考察.下面是在面试过程 ...
- CodeForces 1098E. Fedya the Potter
题目简述:给定长度为$n \leq 5\times 10^4$的序列$a_1, a_2, \dots, a_n \leq 10^5$.将$\gcd(a_l, a_{l+1}, \dots, a_r) ...
- Spring-SpringMVC-Mybatis实例
源码下载:https://pan.baidu.com/s/1kUK7qYj 提取码:3mgb 最近在学习SSM框架,先讲一下这三大框架都有什么作用. SpringMVC: 它用于web层,相当于 ...
- vector 大小
vector定义以后就最好确定大小resize(),否则在vector析构时可能出现 "double free or corruption"这样的错误
- CodeForces Gym 100685J Just Another Disney Problem (STL,排序)
题意:给定你大小未知的n个数,你允许有不超过一万次的询问,每次询问两个数,第i个数是否比第j个数小?然后后台会返回给你一个结果YES或者NO(即一行输入), 然后经过多次询问后,你需要给出一个正确的原 ...