Scala Operators, File & RegExp

CloudNative
• 阅读 1888

Operators

  • Thread.`yield`() 反引号除了用于命名标识符,还可以在调用方法时避免冲突(yield 为 Scala 关键字,但也是 Thread 的方法)
  • 中缀运算符(infix operators),实际是带两个参数的方法,定义时跟普通方法一样;a to b 实际是 a.to(b)
  • 一元运算符(unary operators)

    • +, -, !, ~四个可当做前缀运算符使用,-a 实际是 a.unary_
    • 如果可放在参数后,则是后缀运算符 a identifier
  • 赋值操作符(assignment operators),a operator= b 等价于 a = a operator b
  • 优先性

    • * / % > + - > : > < > > ! = > & > ^ > | > 非操作符 > 赋值操作符
    • 中缀运算符优先于后缀运算符
  • 结合性

    • 所有操作符都是左结合的,除了:

      • : 结尾的操作符

        • 1 :: 2 :: Nil 实际是 1 :: (2 :: Nil)
        • 右结合的二元操作符实际是第二个操作对象的方法,如 2 :: NilNil.::(2)
      • 赋值操作符
  • 如果 f(a,b,c) 调用时 f 不是函数或方法,则等价于 f.apply(a,b,c)

    • f(a,b,c) = value 则等价于 f.update(a,b,c, value);如针对 HashMap 的取值和赋值
    • 常用来构建对象时,省略 new 关键字
  • 提取器 extractors

    • 包含 unapply 方法的伴生对象,伴生对象可以定义成给任意类型做为提取器(如,为 String 自定义一个提取器 Name)
    • 在变量定义时使用
    • 在模式匹配中使用

      • case class 自动附带 applyunapply 方法,在模式匹配中会自动调用
    • 提取任意序列值,需要包含 unapplySeq 方法,返回 Option[Seq[Type]]

      • ~注意unapplyunapplySeq 的参数类型不要定义成一样的~
  • 动态调用 dynamic invocation

    • 定义动态类型

      • import scala.language.dynamics
      • 继承 scala.Dynamic
    • Scala 处理过程

      • foo.method("blah") ~> foo.applyDynamic("method")("blah")
      • foo.method(x = 1, 2) ~> foo.applyDynamicNamed("method")(("x", 1), ("", 2))
      • foo.field ~> foo.selectDynamic("field")
      • foo.varia = 10 ~> foo.updateDynamic("varia")(10)
      • foo.arr(10) = 13 ~> foo.selectDynamic("arr").update(10, 13)
      • foo.arr(10) ~> foo.applyDynamic("arr")(10)

Files & RegExp

  • 读取所有行 Source.fromFile({name/java.io.File}).getLines.toArray,关闭资源 source.close
  • 读取字符,直接迭代 source
  • 读取标准输入 scala.io.StdIn
  • 读取 URL Source.fromURL(url, "UTF-8")
  • 读取字符串 Source.fromString("Hello ww")
  • 读取二进制文件,使用 Java 的库
  • 写文件使用 Java 的库
  • 序列化 @SerialVerionUID(42L) class Name extends Serializable

    • Serializable 为 Scala 中的 trait
    • 也可省略注解,使用默认的 UID
    • Scala 的集合都是序列化的
  • 进程控制

    • 工具包 scala.sys.process,包含隐式转换将 String 转为 ProcessBuilder
    • 执行 shell

      • "ls -l".!! 会执行 ProcessBuilder 并阻塞直到命令退出并返回退出码
      • "ls -l".!! 会将输出作为字符串返回
      • #| 管道: ("ls -l" #| "grep scala").!
      • #> 重定向输出: ("ls -l" #> new File("out.txt")).!
      • #>> 追加:("ls -l" #>> new File("out.txt")).!
      • #< 重定向输入:

        • ("grep scala" #< new File("out.txt")).!
        • ("grep html" #< new URL("http://baidu.com")).!
      • 设置执行目录/环境变量 Process("ls -l", new File("../"), ("LANG", "en_US")).!,环境变量为 (k, v) 序列
    • 在 Java 项目中执行 Scala 脚本 ScriptEngine engine = new ScriptEngineManager().getScriptEngineByName("scala")
  • 正则表达式

    • 工具类 scala.util.matching.Regex
    • 构造正则对象 val pattern = "[0-9]+".r

      • 存在转义、引号等情况时使用 """val pattern = """\s+[0-9]+\s+""".r
    • 捕获组使用括号表示 val patternName = "([0-9]+) ([a-z]+)".r

      • 可定义正则变量作为提取器 val pattern(num, item) = "123 abc" (patternName 与定义的正则名一致)
      • 也可在 for 循环中使用正则变量直接提取捕获组
点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
3年前
java项目中构建scala模块
在maven项目中构建scala模块,这样的话可以java和scala互相调用,最好在环境变量中配置scalahome,ide加载相关的模块进行编译运行。pom中的配置如下:<dependencies<dependency<groupIdorg.scalalang</gro
Wesley13 Wesley13
3年前
vs code上配置Scala
转自:https://www.cnblogs.com/stevenyang/p/5852988.html百度的结果表达太奇怪,简单记一笔。1、下载一个scala的压缩包,https://www.scalalang.org/download/2、配置环境变量3、新建一个文件夹作为工作区。4、新建.vscode文件夹并保存一份tasks.
Stella981 Stella981
3年前
Scala学习笔记03:操作符
Scala学习笔记03:操作符一、scala中操作符与方法的等价性scala中操作符即方法、方法即操作符。scala中操作符其实是普通方法调用的另一种表现形式,运算符的使用其实就是隐含地调用对应的方法。1、操作符即方法!(https://oscimg.oschina.net/oscnet/up6852d9b70e
Stella981 Stella981
3年前
Scala编程快速入门
1.scala数据类型!(https://oscimg.oschina.net/oscnet/2530ebcec5284db427b1db161f02da85037.jpg)上表中列出的数据类型都是对象,也就是说scala没有java中的原生类型。在scala是可以对数字等基础类型调用方法的。例如数字1可以调方法,使用1.
Stella981 Stella981
3年前
Scala系统学习(三):Scala基础语法
如果您熟悉Java语言语法和编程,那么学习Scala将会很容易。Scala和Java之间最大的句法差异在于行结束字符的分号(;)是可选的。当编写Scala程序时,它可以被定义为通过调用彼此的方法进行通信的对象的集合。现在我们简单地看一下类,对象,方法和实例变量的含义。对象 对象有状态和行为。一个对象是类的一个实例。例如狗有状态
Stella981 Stella981
3年前
CDH5.12.1添加spark2.2.0服务
最新的CDH安装包中spark版本为1.6,不过对于勇于尝鲜的同学,官方也提供了spark2的升级包,在CDH中spark1和spark2可以共存,但是由于scala版本的兼容性问题,建议只装一个版本。由于spark依赖于scala所以需要在每个节点安装scala,并配置好SCALA\_HOME并将$SCALA\_HOME/bin加入PATH中。Sca
Stella981 Stella981
3年前
Scala基础
1\.介绍柯里化(currying,以逻辑学家HaskellBrooksCurry的名字命名)指的是将原来接受两个参数的函数变成新的接受一个参数的函数的过程。新的函数返回一个以原有第二个参数作为参数的函数。在Scala中方法和函数有细微的差别,通常编译器会自动完成方法到函数的转换。如果想了解Scala方法和函数的具体区别,请参考博文S
Stella981 Stella981
3年前
Scala之美
1\.介绍      Scala语言拥有很强的表达能力,语法简洁,很接近人类的思考方式。利用map、flatMap方法做数据转换时,层层递进的演算方式,很像是在画流程图,中间没有停顿,思绪很流畅,不会被无关的变量声明、初始化等琐事打断。Scala中的Future可以让你非常灵活的使用线程,而不需要关注底层的线程管理问题,Scala已经为你处
Stella981 Stella981
3年前
PowerDesigner列名、注释内容互换
在用PowerDesigner时,常常在NAME或Comment中写中文在Code中写英文,Name只会显示给我们看,Code会使用在代码中,但Comment中的文字会保存到数据库TABLE的Description中,有时候我们写好了Name再写一次Comment很麻烦,以下两段代码就可以解决这个问题。在PowerDesigner中PowerDesig
Stella981 Stella981
3年前
Scala学习(九)文件和正则表达式
1.读取行要想读取文件中的所有行,可以调用scala.io.Source对象的getLines方法:!(http://c.58qf.com/download/attachments/13179176/image2018108_142040.png?version1&modificationDate1538979638644&a
Stella981 Stella981
3年前
Scala_标识符
用于对象,类,变量和方法的名称称为标识符。关键字不能用作标识符,标识符区分大小写。类名首字母大写方法名称第一个字母小写程序文件名应该与对象名称完全匹配1.字母数字标识符以字母或下划线开头,后跟字母、数字或下划线。$字符是Scala中的保留关键字,不应在标识符中使用2.运算符标识符由一个或