1. 对象的apply方法

    (1)对象调用apply()方法,可省略成()

    (2)string对象的apply方法返回第n个字符

    "hello"(4)  //‘o’
  2. if语句的返回值

    java把语句和表达式看做2个东西,语句执行动作,表达式返回值。eg:if语句没有返回值。而scala中,大部分的语法结构都有返回值。

    (1)if..else..语法结构的返回值 = if/else后面跟随的表达式的值

    scala> val s = if(1>0) 1 else -1
    res0: Int = 1
  3. for

    (1)scala中没有for(初始值;条件;更新变量)结构的循环

    (2)如需这样的循环,2种选择:while / for(i <- 1 to n)

    scala> for(i <- 1 to 5) print(i+",")
    1,2,3,4,5,

(3)scala的for由3部分组成:生成器,守卫,循环体

生成器:变量 <- 表达式

守卫:if语句

循环体:循环的逻辑,如果循环体以yield开始,则for的返回值时一个集合

```scala
for(i <- 1 to 2; j <- 1 to 3)
print(i*j+",") //1,2,3,2,4,6, //带守卫的for
for(i <- 1 to 2; j <- 1 to 3 if j!=2)
print(i*j+",") //1,3,2,6 //yield构建集合
for(i <- 1 to 10)
yield i % 3 //Vector(1, 2, 0, 1, 2, 0, 1, 2, 0, 1)
```
  1. 函数

    //1.默认参数
    def decorate(value:String,left:String="[",right:String="]"): String ={
    left + value + right
    }
    decorate("haha") //[haha] //2.可变参数
    def sum(args:Int*): Int ={
    var sum=0
    for(i <- args)
    sum += i
    sum
    }
    sum(1 to 5: _*) //15q
  2. 懒值

    (1)懒值在第一次被调用时初始化,如果没被使用过,则不去初始化

    (2)每次访问懒值时,scala都会调用一个方法来以线程安全的方式检查该值是否被初始化

    val words = scala.io.Source.fromFile("/home/lj/aaa.txt")         //words被定义时赋值
    def words2 = scala.io.Source.fromFile("/home/lj/aaa.txt") //每次使用words2时被调用
    lazy val words3 = scala.io.Source.fromFile("/home/lj/aaa.txt") //懒值在首次使用时初始化
  3. 异常处理

    scala没有受检异常---不需要声明函数或方法抛出某种异常。try代码快返回Nothing类型

      var in = new URL("http://www.baidu.com").openStream()
    try{
    //TODO
    }finally {
    in.close()
    }

1.scala语法的更多相关文章

  1. scala语法在spark withScope上的应用

    withSpout在spark中是用来做DAG可视化的,它在代码里的用法如下(以map为例,spark 2.0.0版本) def map[U: ClassTag](f: T => U): RDD ...

  2. scala语法解析(解码指环)

    看惯了JAVA的语法,再看scala的语法,有的晦涩难懂.正好遇到一个介绍scala语法的文章,就直接截图留念.省的再临时抱佛脚了.

  3. Scala语法笔记

    JAVA中,举例你S是一个字符串,那么s(i)就是该字符串的第i个字符(s.charAt(i)).Scala中使用apply的方法 JAVA与C++的?:操作符 等同于Scala的 if ( x &g ...

  4. Java和Scala语法比较

    类型推断 挑逗指数: 四星 我们知道,Scala一向以强大的类型推断闻名于世.很多时候,我们无须关心Scala类型推断系统的存在,因为很多时候它推断的结果跟直觉是一致的. Java在2016 年也新增 ...

  5. Spark记录-Scala语法基础

    参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...

  6. Scala 语法基础

    一 简介 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Java虚拟机上,并兼容现有的Java程序.Scal ...

  7. Scala 语法(一)

    (1)基本语法 变量 val var(可变变量): 数据类型 Byte,Char,Int,Short,Long,String(字符),Float,Double,Boolean(true,flase). ...

  8. scala语法

    1:双重for循环(相当于j是i的内存循环):for (i <-0 to n; j <-10 to 20){ println(i);println(j)} 2:单层for循环:for (i ...

  9. Scala语法(二)

    (1)类,对象 //定义类(属性.方法),实例化对象 class counter{ *//主构造器 class counter(name:String,mode:Int){ ... } 实例化:val ...

随机推荐

  1. centos6.3 + db2v9.7的数据库移行

    工作内容如题,我要做的事情大体如下: 1,正确备份可用数据库: 2,安装64位的cent os 6.3: 3,将1备份的数据恢复到新的cent os 6.3系统上. 第一件事情,就是备份一个可用的数据 ...

  2. Codeforces Round #142 (Div. 2)

    A. Dragons 按\(x\)排序. B. T-primes \(x\)是平方数,且根\(\sqrt{x}\)是个质数. C. Shifts 枚举列的位置,对于每行来说,最多只会涉及4个列. D. ...

  3. [AC自动机]题目合计

    我只是想记一下最近写的题目而已喵~ 题解什么的才懒得写呢~ [poj 1625]Censored! 这题注意一个地方,就是输入数据中可能有 ASCII 大于 128 的情况,也就是说用 char 读入 ...

  4. Java——异常

     /* * 异常:   是在运行时期  发生的 不正常情况. *  在java中类的形式对不正常情况进行了描述和封装对象. * * 描述不正常的情况类,就成为异常. * * 问题很多,就意味着描述 ...

  5. 安卓应用运营知识:VersionCode和VersionName

    本文转载于:http://blog.sina.com.cn/s/blog_580a227a0101bdzb.html 小米应用商店运营了大概半年了,过程中有喜有泪,我们在运营过程中,发现有的运营和商务 ...

  6. 论文笔记之:Asynchronous Methods for Deep Reinforcement Learning

    Asynchronous Methods for Deep Reinforcement Learning ICML 2016 深度强化学习最近被人发现貌似不太稳定,有人提出很多改善的方法,这些方法有很 ...

  7. Unity3D研究院编辑器之脚本设置ToolBar

    Unity版本5.3.2 如下图所示,ToolBar就是Unity顶部的那一横条.这里的所有按钮一般情况下都得我们手动的用鼠标去点击.这篇文章我们说说如果自动操作它们 1.自动点击左边四个按钮 (拖动 ...

  8. webbrowser在不同的.netframework版本差异

    这几在做一个浏览器的自动化下载的工具,发现自己做的demo和做的项目代码运行不一致,代码就那么几行,拷贝过去为什么有些行为就不一样呢?经过分析发现原来有.net4.0和.net2.0中的webbrow ...

  9. Oracle数据库——表的创建与管理

    一.涉及内容 1.掌握使用OEM工具创建.修改和删除表. 2.掌握使用SQL语句创建.修改和删除表. 3.掌握使用SQL语句插入.修改和删除数据. 4.理解各种约束的作用,并能够使用OEM工具和SQL ...

  10. rsync-3.0.6-64

    http://rsync.samba.org/ 用的是rsync-3.0.6-12.el6.x86_64 Rsync version 3.1.1 released June 22nd, 2014 Rs ...