scala中常用但其他语言不常见的符号含义 - 心灵空谷幽兰 - 博客园

本文旨在介绍Scala在其他语言中不太常见的符号含义,帮助理解Scala Code。

随着我对Scala学习的深入,我会不断增加该篇博文的内容。

修改记录

----2016.11.23 新增scala中最神秘强大的下划线(_)用处

下面介绍Scala中的符号:

  • :::三个冒号运算符:表示list的连接操作
val one = List(1,2,3)val two = List(4,5,6)val three = one:::two

  输出结果为:three: List[Int] = List(1, 2, 3, 4, 5, 6)

  • :: 两个冒号运算符:表示普通元素与list的连接操作
  • _N下划线数字运算符:用于访问元组的第N个元素,N的取值从1开始。元组的元素访问方法与数组不同是因为元组的元素类型可以不同。
  • -> 返回一个二元元组

  返回:(List[Int], List[Int]) = (List(1, 2, 3),List(4, 5, 6))

  • <- 用于遍历集合对象
  • => 把左边的东西改成右边的东西;可以看做创建函数实例的语法糖,这个运算符常见的有下面三种:
    • =>:Example:Int => String表示函数输入为Int型,返回String型,同Function(Int,String)
    • ()=>:Example:() => T表示函数没有输入参数,但返回T
    • Unit=>:Unit相当于无值的值,相当于C++中的Void
  • _ 有很多含义

      1、通配符

import org.apache.spark.SparkContext._

      2、匿名函数

3、指代集合中的每一个元素。例如筛选列表中大于某个值的元素

val lst = List(1,2,3,4,5)val lstFilter = lst.filter(_ > 3)

   4、使用模式匹配可以用来获取元组的组员。

val m = Map(1 -> 2,2 -> 4)for ((k,_) <- m) println(k)   //如果不需要所有部件,则在不需要的部件使用_;
本例只取key,因此在value处用_

   5、代表某一类型的默认值

对于Int类型来说,它是0

对于Double来说,它是0.0

对于引用类型来说,它是null

  • :_* 作为一个整体,告诉编译器你希望将某个参数当作数序列处理。
val s = sum(1 to 5:_*)      //把1 to 5当作一个序列处理
  • +=:为map类型变量添加元素
  • -=:为map类型变量移除元素及其对应的值

参考文献

 1 http://stackoverflow.com/questions/6951895/what-does-and-mean-in-scala

2 http://docs.scala-lang.org/tutorials/FAQ/finding-symbols.html

3 https://www.zhihu.com/question/21622725/answer/21588672

摘自 :https://www.cnblogs.com/xinlingyoulan/p/6031157.html

原文发布于微信公众号 - Spark学习技巧(bigdatatip)

原文发表时间:2018-01-22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏web

js中push(),pop(),unshift(),shift()的用法小结

1162
来自专栏Java帮帮-微信公众号-技术文章全总结

04.Java对象和类

04.Java对象和类 Java 对象和类 Java作为一种面向对象语言。支持以下基本概念: 多态 继承 封装 抽象 类 对象 实例 方法 重载 本节我们重点研...

4586
来自专栏十月梦想

PHP输出语句

prinf_r()是PHP的内置函数可以输出任意的数据(变量,数组,字符串),也是只能输出一个数据

1066
来自专栏linux驱动个人学习

typeof关键字的作用

一、typeof详解: 前言:     typeof关键字是C语言中的一个新扩展,这个特性在linux内核中应用非常广泛。(其实这和C++的auto关键字和可以...

3375
来自专栏技术之路

详解c++指针的指针和指针的引用

展示一下使用指针的指针和指针的引用修改传递给方法的指针,以便更好的使用它。(这里说的指针的指针不是一个二维数组) 为什么需要使用它们 当我们把一个指针做为参数传...

2036
来自专栏小古哥的博客园

JS数组去重的三种方法

在程序中,通常解决一个问题的方法有很多种。当然这些不同思路的解决方法,在性能和效率上也有很大差异。 以下是数字去重的三种方法, 一、循环遍历法(传统思路) 最简...

3845
来自专栏我爱编程

Day7函数式编程3/3

装饰器 由于函数也是一个对象,而且函数对象可以被赋值给变量,所以,通过变量也能调用该函数。 >>> def now(): ... print('2018...

3767
来自专栏星汉技术

原 荐 Scala的面向对象

----------目录--------------------------------------------------------- 1.Scala简介和...

30713
来自专栏python3

python3--函数进阶

TypeError: func() missing 4 required keyword-only arguments: 'a', 'b', 'c', and ...

951
来自专栏遊俠扎彪

C++中的字符数组、字符串、字符指针的一些笔记

1、sizeof会计算实际内存空间,strlen会计算C风格的字符串的实际字符数(不包括\0)。

19610

扫码关注云+社区

领取腾讯云代金券