定义自己的控制结构,使它语言内置的用法一样

package exp

object Main {
def enableCustomerIF = false;
def main(args: Array[String]): Unit =
IF(1 / 0 == 0) // 这里就不用写 IF(()=>3>2)(()=>println("hello");
{//这不是语言内置的IF,大括号可不能省略
List("hello","world") foreach println;
} //()=>Boolean 替换成 =>Boolean 就可以实现在不传递参数时省略掉()=>了,为避免歧义要在:与=>之间多留一些空格
def IF(condition: => Boolean)(op: => Unit): Unit = //如果 condition 的类型定义成 Boolean表达式 而不是 =>Boolean的函数的话 禁用 enableCustomerIF 也会报错
if (enableCustomerIF && condition) //condition 是函数调用,因此1/0==0在 enableCustomerIF=false时不会执行
op; //op的定义如果是()=>Unit 执行时就要带括号了
}

定义类的可读\写属性

package exp
object Main {
def main(args: Array[String]): Unit =
{
val s = new Stu;
s.age = 10;
println(s.age);
}
} class Stu {
private var n = "";
private var g = 0; def name = this.n;
def name_=(x: String): Unit = this.n = x;//这个定义更标准,生成的代码也很简单 def age = this.g;
def age_= = this.g = _: Int;//这个定义看上去很简单,更函数式,但是不好理解生成的代码更复杂
}

模式匹配实现的表达式解析

package exp {
object Main {
def simplifyTop(ex: Expr): Expr = ex match {
case UnOp("-", Var(x)) => Var("-" + x);
case UnOp("-", UnOp("-", e)) => simplifyTop(e);
case BinOp("+", e, Number(0)) => e;
case BinOp("*", e, Number(1)) => e;
case BinOp("+", Var(x), Var(y)) => Var(x + y);
case BinOp("+", a, b) => BinOp("+", simplifyTop(a), simplifyTop(b))
case _ => ex;
} def main(args: Array[String]): Unit =
{
val x = simplifyTop(BinOp("+", Var("x"), Var("y")));
println(x);
} abstract class Expr;
case class Var(name: String) extends Expr;
case class BinOp(op: String, left: Expr, right: Expr) extends Expr;
case class Number(num: Double) extends Expr;
case class UnOp(op: String, arg: Expr) extends Expr;
} }

foreach 迭代器和 for (p <- x) 循环迭代是不太一样的

object Main {

    def main(args: Array[String]): Unit =
{
val x = 1 to 10;
var i = 0;
x.foreach {
// i = i+1; 放在这里只执行一次 , foreach 和 for(p <- x) 迭代器还是不一样的
p =>{
i = i + 1; //放在这里会执行10次
println(p);
}
} println(i) i = 0;
for (p <- x) {
i = i + 1; //执行10次
println(p);
}
println(i);
} }

  

  

package exp
{
object Main { def main(args: Array[String]): Unit = { //数组传递给可变参数 :_*
def sum(x:Int*)=x.sum;
println(sum(Array(1,2,3):_*)) //匹配数组或列表多个元素 _*
val Array(a,_,b,_*) = Array(1,2,3,4,5);
println(b); val List(c,_,d,_*) = List(1,2,3,4,5,6)
println(d); //模式匹配上变量绑定 @ case UnOp("abs",e@UnOp("abs",_)) => e
} }
}

 

Option 类型的使用

package exp
{
object Main {
def main(args: Array[String]): Unit = {
div(8,1) match{
case None => println("none");
case Some(y) => println(y);
}
} def div(x:Int,y:Int):Option[Int] = if(y==0) None else Some(x/y)
}
}

  

各种格式的函数定义

val foo : Int=>Int = x => x match {
case 0 => 0;
case x => x+1;
} val foo1 : Int=>Int = _ match {
case 0 => 0;
case x => x+1;
} val foo2 : Int=>Int ={ //能省略掉match的只有这一种情况,指定函数类型变量,在case中直接用样本定义函数
case 0 => 0;
case x => x+1;
} val foo3 = (x:Int) => x match {
case 0 => 0;
case x => x+1;
} def foo4(x:Int):Int = x match {
case 0 => 0;
case x => x+1;
} def foo5(x:Int):Int = {
x match
{
case 0 => 0;
case x => x+1;
}
}

  

定义返回函数的函数

def main(args: Array[String]): Unit = {

            val f = (x:Int) => (y:Int)=>x+y;
println(f(3)(2)); val g:Int=>Int=>Int = x=>y=>x+y;
println(g(3)(2)); def fxx(x:Int)(y:Int) = x+y;
println(fxx(3)(2)); def foo(x:Int) = {
val tmp = (y:Int) => x+y;
tmp;
}
println(foo(3)(2)); def foo1(x:Int) = {
def tmp(y:Int) = x+y;
tmp _;
}
println(foo1(3)(2));
}

  

如果函数只有一个变量,并且这个变量在最末尾,则这个变量的下划线也可以省略

def foo(add:Int=>Int):Int= add(2);
println(foo(2+));//p=>2+p 或 2+_ 或 2+

Scala 高级编程练习的更多相关文章

  1. scala 高级编程

    一.函数式编程 Scala中的函数可以独立存在, 不需要依赖任 何类和对象 def  放在类中就是方法:放在外边就是函数 1.将函数赋值给变量 Scala中的函数是一等公民, 可以独立定义, 独立存在 ...

  2. 9、scala函数式编程-集合操作

    一.集合操作1 1.Scala的集合体系结构 // Scala中的集合体系主要包括:Iterable.Seq.Set.Map.其中Iterable是所有集合trait的根trai.这个结构与Java的 ...

  3. scala 函数式编程之集合操作

    Scala的集合体系结构 // Scala中的集合体系主要包括:Iterable.Seq.Set.Map.其中Iterable是所有集合trait的根trai.这个结构与Java的集合体系非常相似. ...

  4. 02.Scala高级特性:第6节 高阶函数;第7节 隐式转换和隐式参数

    Scala高级特性 1.    课程目标 1.1.   目标一:深入理解高阶函数 1.2.   目标二:深入理解隐式转换 2.    高阶函数 2.1.   概念 Scala混合了面向对象和函数式的特 ...

  5. Learning Spark中文版--第六章--Spark高级编程(2)

    Working on a Per-Partition Basis(基于分区的操作) 以每个分区为基础处理数据使我们可以避免为每个数据项重做配置工作.如打开数据库连接或者创建随机数生成器这样的操作,我们 ...

  6. 读《C#高级编程》第1章问题

    读<C#高级编程>第1章 .Net机构体系笔记 网红的话:爸爸说我将来会是一个牛逼的程序员,因为我有一个梦,虽然脑壳笨但是做事情很能坚持. 本章主要是了解.Net的结构,都是一些概念,并没 ...

  7. MVC高级编程+C#高级编程

    本人今年的目标是学习MVC高级编程和C#高级编程,把自己的基础打的扎实,本文中值是一个开到,定期会在上面记录学习的技术点和心得就,加油吧!!!!!

  8. 《C#高级编程》读书笔记

    <C#高级编程>读书笔记 C#类型的取值范围 名称 CTS类型 说明 范围 sbyte System.SByte 8位有符号的整数 -128~127(−27−27~27−127−1) sh ...

  9. jquery插件开发继承了jQuery高级编程思路

    要说jQuery 最成功的地方,我认为是它的可扩展性吸引了众多开发者为其开发插件,从而建立起了一个生态系统.这好比大公司们争相做平台一样,得平台者得天下.苹果,微软,谷歌等巨头,都有各自的平台及生态圈 ...

随机推荐

  1. Selenium 面试题总结(乙醇Blog记录的面试题)

    ###selenium中如何判断元素是否存在? - isElementPresent   ###selenium中hidden或者是display = none的元素是否可以定位到? - 不能   # ...

  2. Storm入门3-集群搭建

    [storm集群的搭建以及将开发好的拓扑提交到集群上运行的方法] 在上一篇文章中,我们的拓扑直接运行,并在程序开始时候自动启动一个本地"集群"来运行拓扑.LocalCluster这 ...

  3. Web API

    https://www.asp.net/web-api/overview/getting-started-with-aspnet-web-api/tutorial-your-first-web-api ...

  4. CSS选择器、标签,div的位置。

    今天是休假,布置了一个作业,是利用CSS制作斯坦福大学官网.虽然是一个并不复杂的制作,却让我第一次体会到了想摔鼠标的感觉. 遇到了很多问题,却找不出自己到底是哪里出了问题,简简单单的一个logo.足足 ...

  5. this 的值到底是什么?

    你可能遇到过这样的 JS 面试题: var obj = { foo: function(){ console.log(this) } } var bar = obj.foo obj.foo() // ...

  6. pyqt官方示例

    文件夹 PATH 列表 卷序列号为 00000058 F027:7BEC C:. ├─activeqt │ └─webbrowser │ ├─icons │ └─pycache ├─animation ...

  7. 用SignalR实现实时查看WebAPI请求日志

    实现的原理比较直接,定义一个MessageHandler记录WebAPI的请求记录,然后将这些请求日志推送到客户端,客户端就是一个查看日志的页面,实时将请求日志展示在页面中. 这个例子的目的是演示如何 ...

  8. Unity3d外包(北京)公司(长年承接U3D外包)

    我们制作各类型严肃游戏,虚拟现实,增强现实项目! 品质保证,售后完备. 联系请加QQ:372900288  电话:13911652504 我们团队成立于2011年10月,是一个专业从事严肃游戏研发的团 ...

  9. 上传文件fileupload

    文件上传: 需要使用控件-fileupload 1.如何判断是否选中文件? FileUpload.FileName -  选中文件的文件名,如果长度不大于0,那么说明没选中任何文件 js - f.va ...

  10. easymock所测试的方法内部新NEW对象的处理

    问题:当记录的方法的参数是方法所在类内部新NEW的对象时,静态的记录方法交互就会失效,例如 调用的方法: public calss A{ public void method(User u){ u.s ...