For语句段

语法:

Expr1 ::= „for‟ („(‟ Enumerators „)‟ | „{‟ Enumerators

„}‟) {nl} [„yield‟] Expr

Enumerators ::= Generator {semi Enumerator}

Enumerator ::= Generator

| Guard

| „val‟ Pattern1 „=‟ Expr

Generator ::= Pattern1 „<-‟ Expr [Guard]

Guard ::= „if‟ PostfixExpr

for语句段for (enums) yield e对于由枚举器enums产生的每一个绑定求值表达式e。

一个枚举器序列总是由一个产生器開始。然后可跟其它产生器,值定义,或守卫。一个产生器 p <- e从一个与模式p匹配的表达式e产生绑定。值定义val p = e将值名称p(或模式p中的数个名称)绑定到表达式e的求值结果上。守卫if
e包括一个布尔表达式。限制了枚举出来的绑定。产生器和守卫的精确含义通过翻译为四个方法的调用来定义:map filter flatMap和foreach。这些方法能够针对不同的携带类型具有不同的实现。

翻译框架例如以下。在第一步里,每一个产生器p <- e,对于e的类型被替换为例如以下形式。p不是不可反驳的(§8.1):

p <- e.filter { case p => true; case _ => false }

然后。下面规则将反复应用。直到全部的语句段都消耗完成。

 for语句段 for (p <- e) yield e‟被翻译为e.map { case p => e‟ }

 for语句段 for (p <- e) e‟ 被翻译为e.foreach { case p => e‟ }

 for语句段 for (p <- e; p‟ <- e‟ ...) yield e‟‟, 这里...是一个产生器或守卫序列(可能为空)。该语句段翻译为 e.flatMap { case p => for(p‟ <- e‟ ...) yield e‟‟ }

 for语句段 for (p <- e; p‟ <- e‟ ...) e‟‟

这里... 是一个产生器或守卫序列(可能为空),该语句段翻译为 e.foreach { case p => for (p‟ <- e‟ ...) e‟‟ }

 后跟守卫if g的产生器p <- e翻译为单个产生器p <- e.filter((x1,...,xn) => g),这里x1,...,xn是p的自由变量。

 后跟值定义val p‟ = e‟的产生器 p <- e翻译为下面值对产生器,这里的x和x‟是新名称: val (p, p‟) <- for (x@p <- e) yield { val x‟@p‟ = e‟; (x, x‟) }

演示样例6.19.1 下面代码产生1到n-1间全部和为素数的数值对

for { i <- 1 until n

j <- 1 until i

if isPrime(i+j)

} yield (i, j)

该for语句段翻译为:

(1 until n)

.flatMap {

case i => (1 until i)

.filter { j => isPrime(i+j) }

.map { case j => (i, j) }

演示样例6.19.2 for语句段能够用来简明地描写叙述向量和矩阵算法。比方下面就是一个函数来计算给定矩阵的转置:

def transpose[A](xss: Array[Array[A]]) = {

for (i <- Array.range(0, xss(0).length)) yield

for (xs <- xss) yield xs(i)

}

下面是一个函数,用来计算两个向量的无向量积:

def scalprod(xs: Array[Double], ys: Array[Double]) = {

var acc = 0.0

for ((x, y) <- xs zip ys) acc = acc + x * y

acc

}

最后。这是一个求两个矩阵的积的函数。

能够与演示样例 6.15.1中的常见版本号做一个比較

def matmul(xss: Array[Array[Double]], yss: Array[Array[Double]] = {

val ysst = transpose(yss)

for (xs <- xss) yield

for (yst <- ysst) yield

scalprod(xs, yst)

}

以上代码使用了类scala.Array中已有定义的成员map, flatMap, filter和foreach。

很多其它精彩内容请关注:http://bbs.superwu.cn

关注超人学院微信二维码:

关注超人学院java免费学习交流群:

Scala---For语句段的更多相关文章

  1. Spark记录-Scala循环语句

    Scala while循环语句 当给定条件为真时,while循环重复一个语句或一组语句.它在执行循环体之前测试条件状态. 只要给定的条件为真,while循环语句重复执行目标语句. object Dem ...

  2. scala学习手记17 - 容器和类型推断

    关于scala的类型推断前面已经提到过多次.再来看一下下面这个例子: import java.util._ var list1: List[Int] = new ArrayList[Int] var ...

  3. 第一章 Scala基础篇

    目录 一.Scala基础语法 (一) 变量.类型.操作符 1.变量申明 2.字符串 3.数据类型 4.操作符 (二)循环判断 1.块表达式 2.条件表达式 3.循环表达式 (三)方法和函数 1.方法 ...

  4. 实验三——for语句及分支结构else-if

    1.本节课学习到的知识点: (1)for语句是循环语句,它可以实现c语句的重复执行 (2)for语句中的3个表达式的执行顺序和书写顺序不同 (3)遇到复合语句时要用大括号将几句话括起来,复合语句在语法 ...

  5. 实验三——for 语句及分支结构else-if

    1.本节课学习到的知识点:在本次课中,我学习了for语句的使用,认识了for语句的执行流,明确了三种表达式的意义.以及最常用的实现多分支的else-if语句. 2.实验过程中遇到的问题及解决方法:在本 ...

  6. 第三次作业——for 语句及分支结构else-if

    1.本次学习到的知识点: (1)else-if的一般形式:if(表达式1)语句1:else if(表达式2)语句2:........else if(表达式n-1)语句n-1:else语句n: (2)遇 ...

  7. MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存

    二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...

  8. 未找到数据,异常处理:exception when no_data_found then 异常处理语句;

    未找到数据. 在 select 字段 Into 变量 from 表 where 条件: 这种语句中很有可能会有select 不到数据的问题,导致报错"未找到数据" 要解决这种问题需 ...

  9. 作业3---for语句及分支结构else-if

    1.本次课学习到的知识点: (1)for语句的一般表达式,执行顺序: (2)指定次序的循环程序设计:数列的累加.累乘等: (3)else-if实现的分支结构可以判断语句的真假 2.实验过程中遇到的问题 ...

随机推荐

  1. HDU ACM 1054 Strategic Game 二分图最小顶点覆盖?树形DP

    分析:这里使用树形DP做. 1.最小顶点覆盖做法:最小顶点覆盖 == 最大匹配(双向图)/2. 2.树形DP: dp[i][0]表示i为根节点,而且该节点不放,所需的最少的点数. dp[i][1]表示 ...

  2. Android动绘图标——I am not a gif maker,I am a developer

    最早在git上发现一个非常酷眩的动绘图标效果: https://github.com/xuyisheng/tickplusdrawable 不得不说,国外的程序猿在细节的考虑上,确实比我们要好非常多, ...

  3. Wix学习整理(2)——HelloWorld安装添加UI

    原文:Wix学习整理(2)--HelloWorld安装添加UI 在前一篇随笔Wix学习整理(1)——快速入门HelloWorld中,我们制作的安装包安装界面太简单,没有与用户进行交互的过程.下面我们修 ...

  4. 浅谈SQL之主键、外键约束

    约束:顾名思义就是一种限制,在表或列的层次设置约束,确保数据的有效性和完整性. SQL server中约束的主要分类: UNIQUE约束(唯一性约束) 防止一个特定的列中两个记录具有相同的值.可设置多 ...

  5. c#控制台应用程序-“进入指定日期检查出星期几”

    这涉及一个算法: 基姆拉尔森计算公式 W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400+1) mod 7 在公式中d表示日期中的日数.m表示月份数.y表示年数. 注意:在公式 ...

  6. JAVA card 应用开发(三) 把APPLET(CAP文件)装载到卡片

    依据前面两篇博文.我们能够在Eclipse上建立好Applet.而且能够有多个AID.能够选择不同的应用. 那么,以上我们都是基于模拟环境的逻辑,实际上有些函数接口是须要实际的环境.就是说我们须要把A ...

  7. 《Java并发编程实战》第七章 取消与关闭 读书笔记

        Java没有提供不论什么机制来安全地(抢占式方法)终止线程,尽管Thread.stop和suspend等方法提供了这种机制,可是因为存在着一些严重的缺陷,因此应该避免使用. 但它提供了中断In ...

  8. 【JS】依据表格ID进行排序(附凝视)

    分享一个前端做的依据表格ID进行排序的方法哈,贴码例如以下: HTML: <input type="button" id="btn1" value=&qu ...

  9. HDU 4998 Rotate

    题意: n次旋转  每次平面绕ai点旋转pi弧度  问  最后状态相当于初始状态绕A点旋转P弧度  A和P是多少 思路: 如果初始X点的最后状态为X'点  则圆心一定在X和X'连线的垂直平分线上  那 ...

  10. Socket开发

    Socket开发框架之消息的回调处理 伍华聪 2016-03-31 20:16 阅读:152 评论:0     Socket开发框架之数据加密及完整性检查 伍华聪 2016-03-29 22:39 阅 ...