ScalaTour 2.函数
/**
* 1. case class与模式匹配
*/
object TestFunction extends App{
def value(expr:Expr): Int = expr match {
case FibonaciExpr(0) => 0
case FibonaciExpr(1) => 1
case FibonaciExpr(n) => value(SumExpr(FibonaciExpr(n-1),FibonaciExpr(n-2)))
case SumExpr(a,b) => value(a) + value(b)
case _ => 0
}
println(value(FibonaciExpr(3)))
}
abstract class Expr
case class FibonaciExpr(n:Int) extends Expr{
require(n >= 0) //PreDef中的方法,用于参数校验
}
case class SumExpr(a:Expr,b:Expr) extends Expr
/**
* 2. scala中函数对代码的简化
*/
object TestFun2 extends App{
val list = List(1,2,3,4,5,6)
println("list包含基数吗:"+list.exists(_ %2 ==1 ))
val fileName = List("warn 2013 msg", "warn 2012 msg","error 2013 msg", "warn 2013 msgs")
println("cat file | grep 'warn' | grep '2013' | wc : "+fileName.filter(_.contains("warn")).filter(_.contains("2013")))
}
/**
* 3. scala的wordcount
*/
object TestWordCount extends App{
val file = List("warn 2013 msg", "warn 2012 msg","error 2013 msg", "warn 2013 msg")
def countInStr(str:String):Int = str.split(" ").count("msg"==_)
val num = file.map(countInStr).reduceLeft(_ + _)
println(num)
}
/**
* 4. 尾递归 : 函数的最后一步返回函数本身,没有其他的操作
* foldLeft的尾递归实现
*/
object TestTailRec extends App{
val file = List("warn 2013 msg", "warn 2012 msg","msg 2013 msg", "warn 2013 msg")
def countInStr(str:String):Int = str.split(" ").count("msg"==_)
println(file.map(countInStr)) //List(1, 1, 2, 1)
def foldLeft(list:List[Int])(init:Int)(f:(Int,Int) =>Int) :Int = {
list match {
case List() => init
case head::tail => foldLeft(tail)(f(head,init))(f)
}
}
println(foldLeft(file.map(countInStr))(0)(_+_)) // 1+1+2+1 = 5 [科里化]
}
/**
* 5. 生成List的for循环
*/
object TestFor2List extends App{
val file = List("warn 2013 msg", "warn 2012 msg","msg 2013 msg", "warn 2013 msg")
def countInStr(str:String):Int = str.split(" ").count("msg"==_)
val counts = for(str <- file) yield countInStr(str)
val num = counts.reduceLeft(_+_)
println(num)
}
/**
* 6. Option类型
*/
object TestOption extends App{
def getProperty(param:String): Option[String] ={
val value = System.getProperty(param)
value match {
case null => None
case _ => Some(value)
}
}
val osName = getProperty("os.name")
println(osName.getOrElse("none")) //1. Option类型的getOrElse方法
osName.foreach(println(_)) // 2. Some类型的值可以作为长度为1的List处理
osName match { //3. Option支持类型匹配
case Some(value) => println(value)
case _ => println("null")
}
}
ScalaTour 2.函数的更多相关文章
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- 探究javascript对象和数组的异同,及函数变量缓存技巧
javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...
- JavaScript权威指南 - 函数
函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...
- C++对C的函数拓展
一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...
- 菜鸟Python学习笔记第一天:关于一些函数库的使用
2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...
- javascript中的this与函数讲解
前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...
- 复杂的 Hash 函数组合有意义吗?
很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...
- JS核心系列:浅谈函数的作用域
一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...
- C++中的时间函数
C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...
随机推荐
- struct和typedef struct的区别
当typedef与结构结合使用时,会有一些比较复杂的情况,而且在C语言和C++里面有略有差别,因此从网上摘录了一些资料. 1 首先: 在C中定义一个结构体类型要用typedef: ...
- leetcode 122. Best Time to Buy and Sell Stock II ----- java
Say you have an array for which the ith element is the price of a given stock on day i. Design an al ...
- JavaWeb学习记录(十九)——开发JSTL自定义标签
一.防盗链标签 import javax.servlet.http.HttpServletResponse;import javax.servlet.jsp.JspException;import j ...
- URAL 1072 Routing(最短路)
Routing Time limit: 1.0 secondMemory limit: 64 MB There is a TCP/IP net of several computers. It mea ...
- Cent OS 6.5安装 php memcached扩展
首先查看memcache的依赖库是否有安装,如果对这个有疑问可以参考php手册的memcache的安装需求说明 命令如下: 查询: rpm -qa | grep libevent 安装:yum -y ...
- Android——进度对话框
java类代码: //普通进度对话框 public void bt8_onClick(View v) { final ProgressDialog progressDialog = new Progr ...
- FZU-2216 The Longest Straight (二分枚举)
题目大意:给n个0~m之间的数,如果是0,那么0可以变为任意的一个1~m之间的一个数.从中选出若干个数,使构成一个连续的序列.问能构成的最长序列的长度为多少? 题目分析:枚举连续序列的起点,二分枚举二 ...
- hdu1003 dp(最大子段和)
题意:给出一列数,求其中的最大子段和以及该子段的开头和结尾位置. 因为刚学过DP没几天,所以还会这题,我开了一个 dp[100002][2],其中 dp[i][0] 记录以 i 为结尾的最大子段的和, ...
- 论文笔记之: Recurrent Models of Visual Attention
Recurrent Models of Visual Attention Google DeepMind 模拟人类看东西的方式,我们并非将目光放在整张图像上,尽管有时候会从总体上对目标进行把握,但是也 ...
- caffe: compile error: Could not open or find file your path~~/resized_data/0 and a total of 2 images .
I0219 14:48:40.965386 31108 net.cpp:76] Memory required for data: 0I0219 14:48:40.965517 31108 layer ...