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

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. AWK命令学习

    使用方法 awk 'pattern {action}' {filenames} 尽管操作可能会很复杂,但语法总是这样,其中 pattern 表示 AWK 在数据中查找的内容,而 action 是在找到 ...

  2. windows10 下访问 virtualbox 虚拟机的linux15.10/16.04 系统 及 用 putty 访问虚拟机的配置

    参考: http://www.doc88.com/p-915707596190.html --- 安装samba http://my.oschina.net/u/2260265/blog/405598 ...

  3. webpack的简单使用

    今天简单的说一下webpack的使用. 打开cmd(也可以用别的看个人爱好) 打开你要创建项目的文件夹: webpack安装: 1.全局安装webpack:$npm install webpack - ...

  4. IE11 iframe alternative

    <OBJECT classid=clsid:8856F961-340A-11D0-A96B-00C04FD705A2> <PARAM NAME=Location VALUE=http ...

  5. GitHub注册账号

    username : hcloudypassword : hujunyun3174email : 370284221@qq.com

  6. 如何挂自己的web项目(免费拥有自己的网站及域名)

    http://www.blogjava.net/qingshow/archive/2010/01/17/309846.html ------------------------------------ ...

  7. JAVA 1.3 (原生数据类型 Primitive Data Type)续

    1. 原生数据类型一共有4类8种 >> 整数类型 int表示一个int代表32位 2^32(-2147483648 - 2147483647) >> 字符类型 byte 表示一 ...

  8. 转:Eclipse快捷键 10个最有用的快捷键

    Eclipse快捷键 10个最有用的快捷键 Eclipse中10个最有用的快捷键组合  一个Eclipse骨灰级开发者总结了他认为最有用但又不太为人所知的快捷键组合.通过这些组合可以更加容易的浏览源代 ...

  9. Kafka 高可用设计

    Kafka 高可用设计 2016-02-28 杜亦舒 Kafka在早期版本中,并不提供高可用机制,一旦某个Broker宕机,其上所有Partition都无法继续提供服务,甚至发生数据丢失对于分布式系统 ...

  10. JSONObject,JSONArray,Map,String之间转换

    http://blog.csdn.net/superit401/article/details/51727739 1.String转JSONObject String jsonMessage = &q ...