1.Map操作

Map(映射)是一种可迭代的键值对(key/value)结构。

所有的值都可以通过键来获取。

Map 中的键都是唯一的。

Map也叫哈希表(Hash tables)。 Map 有两种类型,可变与不可变,区别在于可变对象可以修改它,而不可变对象不可以。 默认情况下 Scala 使用不可变 Map。如果你需要使用可变集合,你需要显式的引入 import scala.collection.mutable.Map 类。

package test

/**
* map的操作;
*/
object MapDemo {
def main(args: Array[String]): Unit = {
var map = Map[String,String]("name" -> "jason","age" -> "500","test_100" -> "test_100","test_101" -> "test_101") //引用可变,支持读写操作;
map += ("city" -> "北京") //新增
println(map) //打印结果为:Map(city -> 北京, name -> jason, test_100 -> test_100, test_101 -> test_101, age -> 500);
val map2 = Map[String,String]("sex" -> "男","brand" -> "apple") //引用不可变,只能第一次写入值,之后只能读取;
//map2 += ("test" -> "报错吗") //此时不能加,直接报错;
val map3 = scala.collection.mutable.Map[String,String]() //引用不可变,支持读写操作;
map3 += ("test" -> "能添加吗") //添加单个元素;
map3 += ("test" -> "改变了") //更新;
map3 += ("success" -> "添加成功了吗","anthor" -> "另外一个") //添加多个元素;
println(map3) //打印结果为:Map(success -> 添加成功了吗, anthor -> 另外一个, test -> 能添加吗);
println(map3.keys) //返回所有的key;
println(map3.values)//返回所有的value;
println(map3.isEmpty) //当map为空时,返回true;
var combine_map = map ++ map2 //合并两个map;
println(combine_map) //打印结果为:Map(city -> 北京, name -> jason, test_100 -> test_100, test_101 -> test_101, age -> 500, brand -> apple, sex -> 男);
combine_map -= ("city","name") //删除指定的key;
println(combine_map) //打印结果为:Map(test_100 -> test_100, test_101 -> test_101, age -> 500, brand -> apple, sex -> 男)
println(combine_map.get("age").get) //返回指定key的值;
println(combine_map.init) //返回所有元素,除了最后一个;
println(combine_map.last) //返回最后一个元素;
println(combine_map.max) //查找最大元素;
println(combine_map.min) //查找最小元素;
println(combine_map.mkString("")) //集合所有元素作为字符串显示;
//println(combine_map.product) //返回集合中数字元素的积;注意得是num型;
println(combine_map.size) //返回map的大小;
println(combine_map.toArray) //集合转数组;
println(combine_map.toBuffer) //返回缓冲区,包含了Map的所有元素;
println(combine_map.toList) //返回List,包含了Map的所有元素;
combine_map.get("test_101").getOrElse("不存在") //根据key取value值,如果不存在返回后面的值;
val keySet = combine_map.keys
val key_iter = keySet.iterator //遍历,迭代map;
while (key_iter.hasNext){
val key = key_iter.next
println(key + ":" + combine_map.get(key).get)
}
println(combine_map.apply("brand")) //返回指定键的值,如果不存在返回 Map 的默认方法;
println(combine_map.contains("test_key")) //如果map中存在指定 key,返回 true,否则返回 false;
val age_count = combine_map.count(x=>{ //计算满足指定条件的集合元素数量;
x._1.equals("age")
})
println(age_count) //打印结果为1;
val drop_map = combine_map.drop(1) //返回丢弃最后n个元素新集合;
println(drop_map) //打印结果为:Map(brand -> apple, sex -> 男);
println(combine_map.empty) //返回相同类型的空map;
println(map.equals(map2)) //如果两个 Map 相等(key/value 均相等),返回true,否则返回false;
println(combine_map.exists(x => { //判断集合中指定条件的元素是否存在;
x._2.equals("男")
}))
println(combine_map.filter(x=>{ //返回满足指定条件的所有集合; 结果为:Map(brand -> apple);
x._1.length > 4
}))
println(combine_map.filterKeys(x=>{ //返回符合指定条件的不可变 Map;
x.equals("test_100")
}))
println(combine_map.find(x=>{ //查找集合中满足指定条件的第一个元素;
x._1.equals(x._2)
}))
combine_map.foreach(x=>{ //循环map里的所有元素;
println(x +"------------")
}) }
}

2.List操作

Scala 列表类似于数组,它们所有元素的类型都相同,但是它们也有所不同:列表是不可变的,值一旦被定义了就不能改变,其次列表 具有递归的结构(也就是链接表结构)而数组不是。

2.1Demo1

object Scala_List {
def main(args:Array[String]):Unit={
val list=List[String]("hello bjsxt","hello bjsxt","hello shsxt","hello gzsxt")
val result = list.count(s=>{
s.equals("hello sdhsxt")
})
println(result)
val result1=list.filter(s=>{
s.equals("hello bjsxt")
})
result1.foreach(println)
println("以下是循环遍历")
val result3=list.map(s=>{
s.split(" ")
})
result3.foreach(arr=>{
arr.foreach(println)
println("*********************")
})
println("????????????????????????????/")
val result4=list.flatMap(s=>{
s.split(" ")
})
result4.foreach(println)
println("................................")
val list1=List[Int](1,2,3,4,4)
list1.foreach(println)
println(";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;")
for(elem<-list1){
println(elem)
}
}
}

2.2Demo2

package test

object listDemo {
def main(args: Array[String]): Unit = {
val list: List[String] = List("a", "b" ,"a")
//为列表预添加元素
println("A" +: list)
//在列表开头添加元素
println("c" :: list)
//在列表开头添加指定列表的元素
println(List("d","e") ::: list)
//复制添加元素后列表
println(list :+ "1")
//将列表的所有元素添加到 StringBuilder
val sb = new StringBuilder("f")
println(list.addString(sb))
//指定分隔符
println(list.addString(sb,","))
//通过列表索引获取元素
println(list.apply(0))
//检测列表中是否包含指定的元素
println(list.contains("a"))
//将列表的元素复制到数组中,在给定的数组xs中填充该列表的最多为长度(len)元素,从start位置开始。
val a = Array('a', 'b', 'c')
val b : Array[Char] = new Array(5)
a.copyToArray(b,0,1)
b.foreach(println)
//去除列表的重复元素,并返回新列表
println(list.distinct)
//丢弃前n个元素,并返回新列表
println(list.drop(1))
//丢弃最后n个元素,并返回新列表
println(list.dropRight(1))
//从左向右丢弃元素,直到条件p不成立
println(list.dropWhile(_.equals("a")))
//检测列表是否以指定序列结尾
println(list.endsWith(Seq("a")))
//判断是否相等
println(list.head.equals("a"))
//判断列表中指定条件的元素是否存在,判断l是否存在某个元素
println(list.exists(x=> x == "a"))
//输出符号指定条件的所有元素
println(list.filter(x=> x.equals("a")))
//检测所有元素
println(list.forall(x=> x.startsWith("b")))
//将函数应用到列表的所有元素
list.foreach(println)
//获取列表的第一个元素
println(list.head)
//从指定位置 from 开始查找元素第一次出现的位置
println(list.indexOf("b",0))
//返回所有元素,除了最后一个
println(list.init)
//计算多个集合的交集
println(list.intersect(Seq("a","b")))
//检测列表是否为空
println(list.isEmpty)
//创建一个新的迭代器来迭代元素
val it = list.iterator
while (it.hasNext){
println(it.next())
}
//返回最后一个元素
println(list.last)
//在指定的位置 end 开始查找元素最后出现的位置
println(list.lastIndexOf("b",1))
//返回列表长度
println(list.length)
//通过给定的方法将所有元素重新计算
list.map(x=> x+"jason").foreach(println)
//查找最大元素
println(list.max)
//查找最小元素
println(list.min)
//列表所有元素作为字符串显示
println(list.mkString)
//使用分隔符将列表所有元素作为字符串显示
println(list.mkString(","))
//列表反转
println(list.reverse)
//列表排序
println(list.sorted)
//检测列表在指定位置是否包含指定序列
println(list.startsWith(Seq("a"),1))
//计算集合元素之和,这个地方必须是int类型,如果是string直接报错
//println(list.sum)
//返回所有元素,除了第一个
println(list.tail)
//提取列表的前n个元素
println(list.take(2))
//提取列表的后n个元素
println(list.takeRight(1))
//列表转换为数组
println(list.toArray)
//返回缓冲区,包含了列表的所有元素
println(list.toBuffer)
//List 转换为 Map
val arr = Array(("jason", 24), ("jim", 25))
arr.toMap.foreach(println)
//List 转换为 Seq
println(list.toSeq)
//List 转换为 Set
println(list.toSet)
//列表转换为字符串
println(list.toString())
}
}

运行结果如下:

List(A, a, b, a)
List(c, a, b, a)
List(d, e, a, b, a)
List(a, b, a, 1)
faba
fabaa,b,a
a
true
a
List(a, b)
List(b, a)
List(a, b)
List(b, a)
true
true
true
List(a, a)
false
a
b
a
a
1
List(a, b)
List(a, b)
false
a
b
a
a
1
3
ajason
bjason
ajason
b
a
aba
a,b,a
List(a, b, a)
List(a, a, b)
false
List(b, a)
List(a, b)
List(a)
[Ljava.lang.String;@51cdd8a
ArrayBuffer(a, b, a)
(jason,24)
(jim,25)
List(a, b, a)
Set(a, b)
List(a, b, a)

3.:: , +:, :+, :::, +++

package test
/**
* scala中的:: , +:, :+, :::, +++, 等操作;
*/
object listTest {
def main(args: Array[String]): Unit = {
val list = List(1,2,3)
// :: 用于的是向队列的头部追加数据,产生新的列表, x::list,x就会添加到list的头部
println(4 :: list) //输出: List(4, 1, 2, 3)
// .:: 这个是list的一个方法;作用和上面的一样,把元素添加到头部位置; list.::(x);
println( list.:: (5)) //输出: List(5, 1, 2, 3)
// :+ 用于在list尾部追加元素; list :+ x;
println(list :+ 6) //输出: List(1, 2, 3, 6)
// +: 用于在list的头部添加元素;
val list2 = "A"+:"B"+:Nil //Nil Nil是一个空的List,定义为List[Nothing]
println(list2) //输出: List(A, B)
// ::: 用于连接两个List类型的集合 list ::: list2
println(list ::: list2) //输出: List(1, 2, 3, A, B)
// ++ 用于连接两个集合,list ++ list2
println(list ++ list2) //输出: List(1, 2, 3, A, B)
}
}

原文作者:JasonLee’blog

scala之map,List,:: , +:, :+, :::, +++操作的更多相关文章

  1. scala的map的操作

    1:map和模式匹配的结合 settings.foreach{case (k,v) => set(k,v)} 2:map转成array settings.entrySet().asScala.m ...

  2. scala 数据结构(八 ):-map映射操作

    在Scala中可以通过map映射操作来解决: 将集合中的每一个元素通过指定功能(函数)映射(转换)成新的结果集合这里其实就是所谓的将函数作为参数传递给另外一个函数,这是函数式编程的特点 以HashSe ...

  3. Scala集合Map

    在scala中Map分为可变长(mutable)和不可变长(immutable) /** * 不可变长map 长度一旦初始化,就不能在进行更改 */ // 通过箭头的方式创建map val map = ...

  4. scala (6) Map

    在scala中Map分为可变长(mutable)和不可变长(imtable) /** * 不可变长map 长度一旦初始化,就不能在进行更改 */ // 通过对偶元组的方式创建map val map = ...

  5. 11. Scala数据结构(下)-集合操作

    11.1 集合元素的映射-map映射操作 11.1.1 看一个实际需求 要求:请将List(3,5,8)中所有的元素都*2,将其结果放到一个新的集合中返回,即返回一个新的List(6,10,16),请 ...

  6. 10. Scala数据结构(上)-集合操作

    10.1 数据结构特点 10.1.1 Scala集合基本介绍 uml => 统一建模语言 1) Scala同时支持不可变集合和可变集合,不可变集合可以安全的并发访问 两个主要的包 不可变集合:s ...

  7. Commons BeanUtils 中对Map的操作

    CSDN学院招募微信小程序讲师啦 程序员简历优化指南! [观点]移动原生App开发 PK HTML 5开发 云端应用征文大赛,秀绝招,赢无人机! Commons BeanUtils 中对Map的操作 ...

  8. Scala学习——函数高级操作

    scala函数高级操作 一.字符串高级操作 多行字符串和插值 package top.ruandb.scala.Course06 object StringApp { def main(args: A ...

  9. Scala基础类型与操作

    Scala基本类型及操作.程序控制结构 Scala基本类型及操作.程序控制结构 (一)Scala语言优势 自身语言特点: 纯面向对象编程的语言 函数式编程语言 函数式编程语言语言应该支持以下特性: 高 ...

随机推荐

  1. windows使用sdelete安全的删除文件

    SDelete是一款来自于微软Sysinternals[1]的应用.使用SDelete可以安全的删除现有文件,以及安全地擦除磁盘的未分配部分中存在的数据(包括已经删除或加密的文件).SDelete使用 ...

  2. SLA

    服务级别协议[编辑] 维基百科,自由的百科全书     跳到导航跳到搜索 本条目可参照外语维基百科相应条目来扩充. 若您熟悉来源语言和主题,请协助参考外语维基扩充条目.请勿直接提交机械翻译,也不要翻译 ...

  3. python3 处理列表嵌套字典去重

    def list_dict(dictlist): def function(date): return date['ip'] dictlist_new = [] for list_dict in di ...

  4. Linux LVM Logical Volume Management 逻辑卷的管理

    博主是一个数据库DBA,但是一般来说,是不做linux服务器LVM 逻辑卷的创建.扩容和减容操作的,基本上有系统管理员操作,一是各司其职,专业的事专业的人做,二是做多了你的责任也多了,哈哈! 但是li ...

  5. Facetoobject_encapsulation

    面向对象程序设计思想 一.思想 处处皆对象. 当提到某一功能时,首先应该想有没有实现该功能的对象,有则调用,没有则创建类.当提到数据时,应该想到属于哪个对象. 1.求1~n的累加和 public cl ...

  6. oracle11g数据库安装采坑记录

    第一处坑: 解决方案: 原文:https://blog.csdn.net/yhj198927/article/details/49178279 1.打开oracle的"Net Manager ...

  7. Navcat连接Mysql报错1521

    原因是新版的MySql密码加密算法改变,导致旧版本的Navcat连接报错. 解决方案: 1.升级Navcat 因为只是本地的Mysql,所以没验证这个方法,网传可以,此处不介绍. 2.修改Mysql加 ...

  8. 在CentOS上安装Singularity高性能容器

    什么是singularity容器 Singularity是劳伦斯伯克利国家实验室专门为大规模.跨节点HPC和DL工作负载而开发的容器化技术.具备轻量级.快速部署.方便迁移等诸多优势,且支持从Docke ...

  9. 解决Tengine健康检查引起的TIME_WAIT堆积问题

    简介: 解决Tengine健康检查引起的TIME_WAIT堆积问题 一. 问题背景 "服务上云后,我们的TCP端口基本上都处于TIME_WAIT的状态"."这个问题在线下 ...

  10. Linux 防火墙基于 CentOS7 的防火墙操作命令

    防火墙服务操作命令 重启防火墙 systemctl restart firewalld 查看防火墙状态 systemctl status firewalld 开启.关闭.重启防火墙 # 开启 serv ...