https://www.cnblogs.com/weilunhui/p/5658860.html

1.++[B]   在A元素后面追加B元素

1
2
3
4
5
6
7
8
9
10
11
12
13
14
scala> val = List(1)
a: List[Int] = List(1)
 
scala> val = List(2)
b: List[Int] = List(2)
 
scala> val = a ++ b
c: List[Int] = List(12)
 
scala> val = List('a')
d: List[Char] = List(a)
 
scala> val = c ++ d
e: List[AnyVal] = List(12, a)

2.++: 与++不同的是使用的右边边的数据类型

1
2
3
4
5
6
7
8
scala> val = List(1)
x: List[Int] = List(1)
 
scala> val = LinkedList(2)
y: scala.collection.mutable.LinkedList[Int] = LinkedList(2)
 
scala> var = x ++: y
z: scala.collection.mutable.LinkedList[Int] = LinkedList(12//y是LinkedList
1
2
scala> var = y ++: x  //使用x的类型
z: List[Int] =List(12)

3.+:  在List的头部增加元素

1
2
3
4
5
6
7
8
scala> val = List(1)
x: List[Int] = List(1)
 
scala> val = 2 +: x
y: List[Int] = List(21)
 
scala> println(x)
List(1)

4./:应用二进制运算符起始值,从左到右遍历迭代所有元素。

1
2
3
4
5
6
7
8
scala> val = List(1,2,3,4)
a: List[Int] = List(1234)
 
scala> val = (5 /: a)(_+_)
b: Int = 15
 
scala> val = (5 /: a)((x,y) => x + y)
c: Int = 15

5.:+:在后面追加元素

1
2
3
4
5
6
7
8
scala> val = List(1)
a: List[Int] = List(1)
 
scala> val = :2
b: List[Int] = List(12)
 
scala> println(a)
List(1)

6.:: 为列表增加单个元素,这是一个右结合的操作符

1
1 :: List(23= List(23).::(1= List(123)

7.::: 在列表的前面追加一个列表,这是一个右结合的操作符

1
List(12::: List(34= List(34).:::(List(12)) = List(1234)

8.:\ 与元素合并后按照操作进行对列表遍历

1
2
3
4
5
6
7
8
scala> val = List(1,2,3,4)
a: List[Int] = List(1234)
 
scala> val = (a :5)(_+_)
b: Int = 15
 
scala> val = (a :5)((x,y) => x + y)
c: Int = 15

9.addString(b: StringBuilder) 对列表中的所有元素迭代将拼接成字符串

1
2
3
4
5
6
7
8
scala> val = List(1,2,3,4)
a: List[Int] = List(1234)
 
scala> val = new StringBuilder()
b: StringBuilder =
 
scala> val = a.addString(b)
h: StringBuilder = 1234

10.addString(b: StringBuilder, sep: String) 使用分隔符输出字符串

1
2
3
4
5
6
7
8
scala> val = List(1,2,3,4)
a: List[Int] = List(1234)
 
scala> val = new StringBuilder()
b: StringBuilder =
 
scala> a.addString(b, ", ")
res0: StringBuilder = 1234

11.addString(b: StringBuilder, start: String, sep: String, end: String) 定义输出以什么开始、分割、结束

1
2
3
4
5
6
7
8
scala> val = List(1,2,3,4)
a: List[Int] = List(1234)
 
scala> val = new StringBuilder()
b: StringBuilder =
 
scala> a.addString(b , "List(" ", " ")")
res5: StringBuilder = List(1234)

12. aggregate[B](z: ⇒ B)(seqop: (B, A) ⇒ B, combop: (B, B) ⇒ B): B 对列表内元素进行求和

1
List('a''b''c').aggregate(0)({ (sum, ch) => sum + ch.toInt }, { (p1, p2=> p1 + p2 })

13.apply(n: Int) 通过索引选择元素

1
2
scala> List('a','b','c').apply(1)
res2: Char = b

这一篇里面有很多关于scala的list的操作的好的知识的更多相关文章

  1. 一次I/O问题引发的P0重大故障[改版重推] 原创 二马读书 二马读书 8月16日 这是前段时间发的一篇文章,很多读者反馈,文章没有揭示故障发生的详细

    一次I/O问题引发的P0重大故障[改版重推] 原创 二马读书 二马读书 8月16日 这是前段时间发的一篇文章,很多读者反馈,文章没有揭示故障发生的详细

  2. 【第一篇】ASP.NET MVC快速入门之数据库操作(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  3. Scala基础类型与操作

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

  4. 《手把手教你》系列技巧篇(五十)-java+ selenium自动化测试-字符串操作-上篇(详解教程)

    1.简介 自动化测试中进行断言的时候,我们可能经常遇到的场景.从一个字符串中找出一组数字或者其中的某些关键字,而不是将这一串字符串作为结果进行断言.这个时候就需要我们对字符串进行操作,宏哥这里介绍两种 ...

  5. 《手把手教你》系列技巧篇(五十一)-java+ selenium自动化测试-字符串操作-下篇(详解教程)

    1.简介 自动化测试中进行断言的时候,我们可能经常遇到的场景.从一个字符串中找出一组数字或者其中的某些关键字,而不是将这一串字符串作为结果进行断言.这个时候就需要我们对字符串进行操作,宏哥这里介绍两种 ...

  6. 3-(基础入门篇)稍微了解一下(需要知道的关于Lua的一些基本的知识)

      http://www.cnblogs.com/yangfengwu/p/8948935.html 基础教程源码链接如果失效,请在淘宝介绍中下载,由于链接很容易失效,如果失效请联系卖家,谢谢 htt ...

  7. Scala的文件读写操作与正则表达式

    目录 在本篇博客中你将会学习并了解常用的文件处理任务,例如读取文件的一行文本,本博客的要点包含: Source.fromFile(...).getLines.toArray 输出文件所有行 Sourc ...

  8. 《手把手教你》系列进阶篇之3-python+ selenium自动化测试 - python几种骚操作你都知道吗?(详细教程)

    1. 简介 这篇文章主要是给小伙伴或者童鞋们介绍和分享 python几种骚操:读取配置文件.获取根目录的相对路径.获取系统时间和格式化时间显示.字符串切割等等操作.为后边的自动化框架打下一个结实的基础 ...

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

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

随机推荐

  1. SQL中使用关键词创建表或字段

    有时候我们给表或者字段命名时,会无意中选择了一个SQL中的关键字进行命名,然后就报错了: ERROR:  syntax error at or near "limit" MySQL ...

  2. verilog写的LCD1602 显示

    在读本文之前,请先阅读 LCD1602 的 datasheet(百度到处都是) ,熟悉有关的11条指令集. LCD1602的11个指令集链接 http://www.cnblogs.com/aslmer ...

  3. spring AOP详解四

    AOP(Aspect Orient Programming),作为面向对象编程的一种补充,广泛应用于处理一些具有横切性质的系统级服务,如事务管理.安全检查.缓存.对象池管理等.AOP 实现的关键就在于 ...

  4. 【Luogu】P2486染色(树链剖分)

    题目链接 线段树维护左端颜色,右端颜色,颜色段数量. 合并的时候看左子树的右端颜色是不是等于右子树的左端颜色,如果等于那么颜色段数量要-1S 然后在树剖跳链的时候搞同样的操作qwq 然后就没有然后了 ...

  5. 【Luogu】P2515软件安装(树形DP)

    题目链接 这么水的题我一遍没A,而且前两次提交都只有十分.气死我了.本来我的博客拒收水题来着. Tarjan缩点之后跑树形DP即可. #include<cstdio> #include&l ...

  6. Tarjan的强联通分量

    求强联通分量有很多种. <C++信息学奥赛一本通>  中讲过一个dfs求强联通分量的算法Kosdaraju,为了骗字数我就待会简单的说说.然而我们这篇文章的主体是Tarjan,所以我肯定说 ...

  7. HDU——5667Sequence(矩阵快速幂+费马小定理应用)

    Sequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total S ...

  8. python 命令行传入参数

    创建 test.py 文件,代码如下: #!/usr/bin/python # -*- coding: gbk -*- import sys print sys.argv if __name__==' ...

  9. Mondriaan's Dream(poj 2411)

    题意:在n*m的方格里铺1*2的骨牌,有多少种方案 /* 第一次做插头DP,感觉和状压差不多. 这道题是利用上一行的状态来更新下一行的状态. 1代表上一行这个位置填了一个竖的(即本行可以填): 0代表 ...

  10. hdu 3478 Catch 二分图染色

    题目链接 题意 小偷逃跑,从某个点出发,每下一个时刻能够跑到与当前点相邻的点. 问是否存在某一个时刻,小偷可能在图中的任意一个点出现. 思路 结论 如果该图为连通图且不为二分图,则可能,否则不可能. ...