Scala Operators, File & RegExp
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 :: Nil是Nil.::(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自动附带apply和unapply方法,在模式匹配中会自动调用
- 提取任意序列值,需要包含
unapplySeq方法,返回Option[Seq[Type]]- ~
注意,~unapply和unapplySeq的参数类型不要定义成一样的
- ~
- 包含
- 动态调用 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 SerializableSerializable为 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 循环中使用正则变量直接提取捕获组
Scala Operators, File & RegExp的更多相关文章
- Scala学习笔记之二--基本数据类型
前言 本篇主要讲Scala的基本数据类型,更多教程请参考:Scala教程 基本数据类型 Scala一共提供了9中数据类型,Scala的基本数据类型与java中的基本数据类型是一一对应的,这是Scala ...
- Scala笔记整理
使用类型参数化数组(Array) 创建java.math.BigInteger实例: var big = new java .math.BigInteget("12345678") ...
- Scala 编程(四)内建控制结构
if 表达式 Scala 的 if 如同许多其它语言中的一样工作.它测试一个状态并据其是否为真,执行两个分支中的一个: var filename = "default.txt" i ...
- Scala学习之for 循环和 yield 的例子
for循环中的 yield 会把当前的元素记下来,保存在集合中,循环结束后将返回该集合.Scala中for循环是有返回值的.如果被循环的是Map,返回的就是Map,被循环的是List,返回的就是Lis ...
- Scala基础类型与操作
Scala基本类型及操作.程序控制结构 Scala基本类型及操作.程序控制结构 (一)Scala语言优势 自身语言特点: 纯面向对象编程的语言 函数式编程语言 函数式编程语言语言应该支持以下特性: 高 ...
- Programming In Scala笔记-第七章、Scala中的控制结构
所谓的内建控制结构是指编程语言中可以使用的一些代码控制语法,如Scala中的if, while, for, try, match, 以及函数调用等.需要注意的是,Scala几乎所有的内建控制结构都会返 ...
- Scala学习笔记:重要语法特性
1.变量声明 Scala 有两种变量, val 和 var val的值声明后不可变,var可变 val msg: String = "Hello yet again, world!&quo ...
- Scala - 快速学习02 - 搭建开发环境
1- 下载与安装 下载链接:http://www.scala-lang.org/download/ CMD To run Scala from the command-line, simply dow ...
- Scala详解
1 快速入门... 4 1.1 分号... 4 1.2 常变量声明... 4 1.2.1 val常量... 4 1.2.2 ...
随机推荐
- C#中的虚函数virtual
简单介绍虚函数virtual 在某基类中声明 virtual 并在一个或多个派生类中被重新定义的成员函数称为虚函数. 虚函数的作用就是实现多态性(Polymorphism),多态性是将接口与实现进行分 ...
- TinyMCE入门
引入TinyMCE脚本 <script src="https://cdn.tiny.cloud/1/no-api-key/tinymce/5/tinymce.min.js" ...
- OPATCH在线补丁
如果补丁中有online目录就是在线补丁,不需要数据库停机,在线的又分集群和非集群,如下 查看readme可以得知在线补丁打法 $ cat README.txt Oracle Database 11g ...
- Mysql数据库之慢查询
一.简介 开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能. 二.参数说明 slow_query_log 慢查询开启状态 slow_ ...
- 数据分析——python基础
前言:python数据分析的基础知识,简单总结,主要是为了方便自己写的时候查看(你们可能看不太清楚T^T),发现有用的方法,随时补充,欢迎指正 数据分析专栏: 数据分析--python基础 数据分析- ...
- Java多线程编程核心技术-第2章-对象及变量的并发访问-读书笔记
第 2 章 对象及变量的并发访问 本章主要内容 synchronized 对象监视器为 Object 时的使用. synchronized 对象监视器为 Class 时的使用. 非线程安全是如何出现的 ...
- 水晶报表 VS2010 应用
VS.NET2010水晶报表安装部署[VS2010] 欢迎C#高手加盟QQ群:9340166 水晶报表VS2010版IDE安装标准版SAP Crystal Reports, version for ...
- 2015-2016 ACM ICPC Baltic Selection Contest D - Journey(广搜)
- datatime模块的使用
dt_now = datetime.datetime.now()print(dt_now)# 2019-05-09 14:44:32.555337 获取日期,不含时分秒today = dt_now.d ...
- spark基础知识二
主要围绕spark的底层核心抽象RDD进行理解.主要包括以下几个方面 RDD弹性分布式数据集的概念 RDD弹性分布式数据集的五大属性 RDD弹性分布式数据集的算子操作分类 RDD弹性分布式数据集的算子 ...