【Scala专栏】字符串与集合

news2024/11/6 9:34:29

本文索引

  • 一、String/StringBuilder
  • 二、Array
  • 三、List
  • 四、Set
  • 五、Map
  • 六、Tuple

  Scala中的字符串在本质上就是Java的字符串String,
在这里插入图片描述
所以在用法上除了要符合Scala的语法以外,其他方面是如出一辙的。
  Scala中的集合分为可变和不可变,默认声明的结果是不可变的。
  不可变和可变指的是:当集合进行增删操作(长度发生变化)时,不可变集合会返回新的集合,原集合不会变化,而可变集合会在原集合上进行修改。

一、String/StringBuilder

object Lesson_String {
  def main(args: Array[String]): Unit = {
    val str = "abcd"
    val str1 = new String("abcd")
    // Java/Scala输出都是true
    println(str.equals(str1))
    // Scala输出是true, Java中这个是false
    println(str == str1)
    val str2 = "ABCD"
    // 忽视大小写的匹配,输出true
    println(str.equalsIgnoreCase(str2))
    // b的index
    println(str.indexOf(98))
    println(str.indexOf("bd"))
    /** StringBuilder * */
    // Scala中无参构造可以不写()
//    val strBuilder = new StringBuilder
    val strBuilder = new StringBuilder()
    strBuilder.append("abc")
    strBuilder + 'd'
    // 字符串用++=
    strBuilder ++= "efg"
    strBuilder += 'h'
    strBuilder.append(1.0)
    strBuilder.append(18f)
    println(s"strBuilder: $strBuilder")
  }
}

println(s"strBuilder: $strBuilder"),这是一种占位符填充式的String字符串拼接的方式,是一个语法糖,比起直接用"+"来拼接字符串能更加优雅

二、Array

创建一维数组并赋值

val arr1 = new Array[Int](3)
arr1(0) = 10   // 等价于Java: arr1[0] = 10;
// 创建String类型的数组,直接赋值: 其本质是会去调Array对象中重写的apply()方法
val arr2 = Array[String]("s100", "s200", "s300")
// 源码:
/*    def apply[T: ClassTag](xs: T*): Array[T] = {
      val array = new Array[T](xs.length)
      var i = 0
      for (x <- xs.iterator) { array(i) = x; i += 1 }
      array
    }*/

创建二维数组并赋值

val twoDimenArray = new Array[Array[Int]](3)
twoDimenArray(0) = Array[Int](1, 2, 3, 4)
twoDimenArray(1) = Array[Int](5, 6, 7, 8)
twoDimenArray(2) = Array[Int](9, 10, 11, 12)

concat函数: 拼接Array

Array.concat(arr3, arr4).foreach(println)

fill函数: 初始化不可变Array

val immutableArray = Array.fill(3)("hello1")
immutableArray.foreach(println)

初始化可变的Array

 val mutableArray = ArrayBuffer[String]("hello","scala")
 mutableArray.+=("!")
 mutableArray.+=:("!")
 mutableArray.append("!","!")
 mutableArray.foreach(println)

三、List

创建list

val list = List[String]("hello scala", "hello java", "hello spark")

map函数 => n:m输入输出

val splitList: List[Array[String]] = list.map(ele => ele.split(" "))

flatMap => n:1输入输出

val flatSplitList: List[String] = list.flatMap(ele => ele.split(" "))

filter => true的会留下

val filterList: List[String] = list.filter(ele => {
  "hello scala".equals(ele)
})

count => 统计true的element数量

val count: Int = list.count(ele => {
  ele.length > 7
})

可变的List

val listBuffer: ListBuffer[Int] = ListBuffer[Int](1, 2, 3)
listBuffer.append(7)
listBuffer.+=:(-1)
println(s"listBuffer: $listBuffer")

笔者注:以上这些流式计算的函数,可以在编程时大大减少代码的编写量,效果很强大,也是函数式编程的一大特点。 Java8中的stream流也是借鉴了这种函数编程的思想而出现的。 不仅是List集合,对于其他集合也是一样的使用,未来在使用flink/spark等流批统一的计算框架时,会经常用到

四、Set

创建Set

val set: Set[Int] = Set[Int](1, 2, 3, 4, 4, 5)
val set1: Set[Int] = Set[Int](4, 5)

取交集/差集/并集

// 取交集
val set2: Set[Int] = set.intersect(set1)
println(set2)
// 差集: set - set1
val set3: Set[Int] = set.diff(set1)
println(set3)
// 操作符: &取交集
val set4: Set[Int] = set & set1
println(set4)
// 操作符: &~diff
val set5: Set[Int] = set &~ set1
println(set5)
// 操作符: |取并集
val set6: Set[Int] = set | set1
println(set6)

filter: true的会留下

val filterSet: Set[Int] = set.filter(ele => {
   ele > 2
})
println(filterSet)

可变Set

val mutableSet: mutable.Set[Int] = mutable.Set[Int](7, 7, 7)
mutableSet.+=(77)
println(mutableSet)

五、Map

Map中的每个元素,实际上的存储结构其实是Tuble_2(2元组)类型,这个数据类型等下会提到,我们先来上手Map的Api

创建map

val map = Map[String, Int]("a" -> 100, "b" -> 200,("c", 300),("c", 400))

map中直接get(“key”)返回是Option类型,这个类型是Some(有值)/None(无值)的父类

返回Some

// Some(100)
val elementA: Option[Int] = map.get("a")
println(elementA)
val aValue: Int = elementA.get
println(aValue)

返回None

val elementD: Option[Int] = map.get("d")

获取值并赋予默认值

// getOrElse
val dDefaultValue: Int = elementD.getOrElse(777)
println(dDefaultValue)

获取keys

// keys
val keys: Iterable[String] = map.keys
keys.foreach(println)

根据keys遍历得到values

keys.foreach(key => {
  val value = map(key)
  println(s"key=$key,value=$value")
})

直接获取values

val values: Iterable[Int] = map.values
values.foreach(value => println(s"value=$value"))

合并map

// map.++()
val map1 = Map[String,Int](("a",1),("b",2),("c",3),("d",4))
val map2 = Map[String,Int](("a",100),("b",200),("c",300),("e",500))
val map3: Map[String, Int] = map1.++(map2)

可变的map

val mutableMap = mutable.Map[String,Int](("a",1),("b",2),("c",3),("d",4),("e",5))
mutableMap.put("a",100)

filter函数

val mapFilter: mutable.Map[String, Int] = mutableMap.filter(tuple => {
  "a".equals(tuple._1) && 100 == (tuple._2)
})

六、Tuple

Tuple,同Python中的Tuple一样的概念,但是Scala中最多支持Tuple中有22个元素,也就是Tuple22,而Python中则没有这个限制。

什么是元组?

一堆元素放在一个()里面
与列表一样,与列表不同的是元组可以包含不同类型的元素.元组的值是通过将单个的值包含在圆括号中构成的.
元组可以new, 也可以不new, 也可以直接写(ele1,ele*)

创建元组

val tuple1: Tuple1[String] = new Tuple1("hello tuple")
val tuple2: (String, Int) = new Tuple2("hello tuple", 100)
val tuple3: (Int, Boolean, Char) = new Tuple3(1, true, 'C')
// 类似object.apply()的实现方式, 但其实是class
val tuple4: (Int, Double, String, Boolean) = Tuple4(1, 3.4, "abc", false)
val tuple6: (Int, Int, Int, Int, Int, String) = (1, 2, 3, 4, 5, "abc")
// 最大的tuple
val tuple22 = new Tuple22(1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22)

遍历元组:不能通过for循环遍历,只能通过iterator迭代器遍历

val tupleIterator: Iterator[Any] = tuple6.productIterator    while(tupleIterator.hasNext){
  println(tupleIterator.next())
}
tupleIterator.foreach(println)

对于二元组Tuple2特有的交换2个元素的方法Tuple2.swap

val tuple2 = Tuple2(1,2)
tuple2.swap
// 这里会输出(2,1)

scala中的下划线_有2个作用,一个是在遍历时指代集合中的每一个元素,例如有这样一个迭代器Iterator((3,1),(2,3)),就可以用在遍历时用_代替里面的元组元素,例如:

val tupleIterator = Iterator((3,1),(2,3))
tupleIterator.foreach(println(_))
上面这行可以进一步简化为: tupleIterator.foreach(println)

下划线_还有一个作用是用来获取元组中的元素,比如有这样一个二元组tuple2 = (1,3),那么我们用tuple2_2就可以获取到其中的元素3

出个小作业,下面这行输出的结果是什么?答案请分享在评论区

知识补充: minBy可以根据元素的位置输出最小值

val t: (Int, Iterator[(Int,Int)]) = (122,Iterator[(Int,Int)]((3,1),(2,3)))
val tuple: (Int, Int) = t._2.minBy(_._2)
println(tuple)

今天的内容也比较多,要认真学习和理解哦,我们下期再见!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/54687.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

内核编译 --- 链接器

先回顾一下编译知识 将一个程序的编译分为两个大的阶段&#xff1a;编译阶段和链接阶段 编译阶段又分为三个步骤&#xff1a;预编译&#xff0c;编译&#xff08;此编译和上面程序的编译不是同一个意思… 上面那个是指宽泛的编译&#xff09;和汇编 编译阶段经过预编译、编译…

笔记 vue3如何引入iconfont

本次采用的免费字体图标是iconfont 1、点我进入官网 2、具体流程 1、 需要什么图标在上面搜索框查找&#xff0c;然后加入购物车&#xff0c;选完后再点右上角的购物车 2、添加到项目中&#xff0c;有项目就选项目添加&#xff0c;没有就创建项目 3、确定后进入你的项目(可以…

契约测试理论篇

契约测试理论篇 目录契约测试理论篇什么是契约测试契约测试存在一些的问题契约测试的主要实践总结随着 Web 系统的大规模发展&#xff0c;Web API 已经成为了一种广泛使用的技术&#xff0c;再加上微服务和云系统的普及&#xff0c;Web API 的数量呈几何增长。比如在一个大型 W…

pandas 将一行拆分为多行,将多行合并为一行

需求描述 在今天的数据需求&#xff0c;现在要统计各个场景下的类目种类数&#xff0c;并列出对应都有哪些类目。 现在面临的问题是&#xff1a;每个客户的应用场景不同&#xff0c;购买的类目也有多种。 &#x1f39e;&#x1f39e;&#x1f39e;&#x1f39e;&#x1f39e;&…

postgres源码解析38 表创建执行全流程梳理--4

本文讲解非系统表的创建逻辑&#xff08;[<fontcolor0000dd>普通表和索引表]&#xff09;&#xff0c;其入口函数为heap_create&#xff0c;内部公共接口函数为RelationBuildLocalRelation和RelationCreateStorage相关知识回顾见&#xff1a; postgres源码解析38 表创建执…

宝宝入托,爸妈要避开这5种心态

孩子入托&#xff0c;父母也要做好心理准备&#xff0c;尤其需要避免以下5种常见的、不良心理状态&#xff0c;否则会加重孩子入托的困难度。 01.“生离死别式”的入托状态 即每次送孩子入园&#xff0c;就像一场生离死别。宝宝屋里哭&#xff0c;家长屋外哭&#xff0c;最后多…

大数据编程实验四:SparkStreaming编程

大数据编程实验四&#xff1a;SparkStreaming编程 文章目录大数据编程实验四&#xff1a;SparkStreaming编程一、实验目的与要求二、实验内容三、实验步骤1、利用Spark Streaming对不同类型数据源的数据进行处理2、完成DStream的两种有状态转换操作3、完成把DStream的数据输出保…

推荐一个对pytorch代码详细注释的github项目

今天在无意间找一个pytorch代码和注释的Github项目。 先上项目&#xff1a; https://github.com/labmlai/annotated_deep_learning_paper_implementations 这个项目还有个网站&#xff0c;地址&#xff1a;https://nn.labml.ai/ 这个项目将论文和pytorch代码结合起来&#xff…

jsp源码商城系统Myeclipse开发mysql数据库servlet开发java编程计算机网页项目

一、源码特点 JSP 源码商城系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统采用serlvetdaobean mvc 模式&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发…

想学习如何把excel图片转表格?1分钟教会你图片转表格怎么转

应该有不少小伙伴接收过上司或领导以图片格式发送过来的excel表格吧&#xff1f;并且还会要求我们将里面的内容整理为电子档&#xff0c;便于后期的内容编辑以及数据修改。 而当你们收到这种任务时&#xff0c;是怎么去操作的呢&#xff1f;是不是大部分人会选择手动重新制作&a…

【数据可视化】第四章—— 基于pandas的数据可视化(pandas数据结构)

文章目录前言1. Pandas库的引用2. Pandas库的数据类型2.1 Series类型2.2 Series创建方式2.3 Series类型的基本操作2.3.1 Series类型的切片和索引2.3.2 Series类型的对齐操作2.3.3 Series类型的name属性2.3.4 Series类型的修改2.4 DataFrame类型2.5 DataFrame类型创建2.6 DataFr…

毕设选题推荐基于python的django框架医院预约挂号系统

精彩专栏推荐订阅&#xff1a;在 下方专栏&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f496;&#x1f525;作者主页&#xff1a;计算机毕设老哥&#x1f525; &#x1f496; Java实战项目专栏 Python实…

公网SSH远程连接内网Ubuntu主机【cpolar内网穿透】

SSH为建立在应用层基础上的安全协议&#xff0c;专为远程登录会话和其他网络服务提供安全性的协议。但在没有公网IP的环境下&#xff0c;只能在同个局域网下远程。 本篇教程主要实现通过内网穿透&#xff0c;在公网环境下SSH远程登录内网的Ubuntu主机&#xff0c;突破局域网的…

manjaro gnome 记录 3 配置国内镜像源

manjaro gnome 记录 3 配置国内镜像源初manjaro 记录 3 配置国内镜像源更改这个文件设置源初 希望能写一些简单的教程和案例分享给需要的人 manjaro 记录 3 配置国内镜像源 打开图像界面的软件管理&#xff0c;点击右上角&#xff1a;三个点的图标 点击首选项 输入管理员密…

Day17-购物车页面-收获地址-初步封装my-address组件

1.创建收货地址组件&#xff08;my-address&#xff09; 我的操作&#xff1a; 1>在uni_modules文件夹右键新建一个组件 2>还需要自己补全代码 1>和2>的阶段效果图&#xff1a; my-address组件已经被渲染成功了。 *********************************************…

一文看懂linux 内核网络中 RPS/RFS 原理

1 自带 irqbalance 瓶颈 基于简单的中断负载均衡(如系统自带的irqbalance进程)可能会弄巧成拙。因为其并不识别网络流&#xff0c;只识别到这是一个数据包&#xff0c;不能识别到数据包的元组信息。 在多处理器系统的每个处理器都有单独的硬件高速缓存&#xff0c;如果其中一…

黑马程序员软件测试实战项目

Ego微商 “Ego微商”微信小程序应用&#xff0c;主要针对于有特色的食品类商品线上零售。通过微信平台的大流量入口&#xff0c;在一定程度上升高了特色食品的影响力&#xff0c;同时借助微信的模板消息快速推送更新的商品&#xff0c;实现轻量级应用的C2C或者是B2C的线上销售…

《论文阅读》BALM: Bundle Adjustment for Lidar Mapping

留个笔记自用 BALM: Bundle Adjustment for Lidar Mapping 做什么 首先是最基础的&#xff0c;Structure-from-Motion&#xff08;SFM&#xff09;&#xff0c;SFM可以简单翻译成运动估计&#xff0c;是一种基于dui8序列图片进行三维重建的算法。简单来说就是是从运动中不同…

12月2日第壹简报,星期五,农历十一月初九

12月2日第壹简报&#xff0c;星期五&#xff0c;农历十一月初九1. 银保监会&#xff1a;2023年1月起在北京、上海、江苏、浙江、福建、广东等10个省市开展商业养老金业务试点。2. 国家首批未来产业科技园试点名单出炉&#xff1a;空天科技未来产业科技园、未来能源与智能机器人…

2022-12-02 编译Android平台OpenCV,用到读取视频时报错:AMediaXXX

文章目录编译Android平台OpenCV&#xff0c;用到读取视频时报错&#xff1a;解决参考编译Android平台OpenCV&#xff0c;用到读取视频时报错&#xff1a; ld: error: undefined symbol: AMediaExtractor_new ld: error: undefined symbol: AMediaExtractor_setDataSourceFd ld…