文章目录
哈希表
默认的map类型也是immutable中的不可变类型,返回新哈希表
定义哈希表
// 默认的map类型也是immutable中的不可变类型
val map1:Map[String,Int] = Map("ldsx1"->1,"ldsx2"->2)
添加元素
+=
// map添加元素,返回新map,这是使用了var,变量一直重新指向
var map2:Map[String,Int] = Map()
map2 += ("LDSX1"-> 1)
map2 += ("LDSX2"->2)
map2 += ("LDSX3"->3)
//更新了LDSX3的值
map2 += ("LDSX3"->4)
println(map2)
//Map(LDSX1 -> 1, LDSX2 -> 2, LDSX3 -> 4)
删除元素
-=
map2 -=("LDSX1")
println(map2)
//Map(LDSX2 -> 2, LDSX3 -> 4)
对于可变的map,使用remove
合并集合
++
val map3:Map[String,Int] = Map("ldsx1"->1,"ldsx2"->2)
val map4:Map[String,Int] = Map("ldsx1"->3,"ldsx3"->3)
println(map3++map4)
//Map(ldsx1 -> 3, ldsx2 -> 2, ldsx3 -> 3)
访问元素
get这个方法返回一个Option类型,如果键存在,则返回Some(value),其中value是与键"ldsx1"对应的值,如果键不存在,则返回None。
这种方式更安全,因为它强制你处理键可能不存在的情况。
例如,如果你有一个 Map,并且你尝试获取一个键对应的值,结果可能会是 Some(value)(如果键存在)或 None(如果键不存在)。
println(map3.get("ldsx1"))
//Some(1)
println(map3.get("ldsx6"))
//None
//如果键不存在,Scala会抛出一个NoSuchElementException异常。
println(map3("ldsx1"))
keys,values
// Map(LDSX2 -> 2, LDSX3 -> 4)
println(map2.keys,map2.values)
//(Set(LDSX2, LDSX3),MapLike(2, 4))
// 获取
map3.keys.foreach(i =>{
print("Key = " + i)
println(" Value = " + map3(i))}
)
// 解包可用双变量
for ((k,v) <- map3){
println(k,v)
}
println(map3)
isEmpty
println(map2.isEmpty) //false
contains
println(map2.contains("ldsxaa")) //false
size
无length方法使用size
println(map2.size) //2
filter
其中_
代表集合中的每个元素,即键值对。_._1
访问元组的第一个元素(键),然后调用.length
方法来检查键的长度是否大于2
val map6 = Map("one" -> 1, "two" -> 2, "three" -> 3, "four" -> 4)
val filteredMap3 = map6.filter(_._1.length >3)
val filteredMap3 = map6.filter{case (a:String,b:Int)=>a.length>b}
filterKeys
val map6 = Map("one" -> 1, "two" -> 2, "three" -> 3, "four" -> 4)
// 过滤出键长度大于2的键值对
val filteredMap = map6.filterKeys( _.length > 2)
toSet,toList,toArray,toString
println(map3.toSet)
println(map3.toList)
println(map3.toArray)
println(map3.mkString(","))
//Set((ldsx1,1), (ldsx2,2))
//List((ldsx1,1), (ldsx2,2))
//[Lscala.Tuple2;@58651fd0
//ldsx1 -> 1,ldsx2 -> 2
其余常用方法
方法同其余容器类型数据
head,last
take,takeRight
init,tail
drop dropRight
fold,reduce,sum
dropWhile,
forall,foreach