1.简化代码

package com.scala.first

import java.io.File
import javax.management.Query /**
* Created by common on 17-4-5.
*/
object FileMatcher { def main(args: Array[String]) { for (file <- filesHere)
println(file) println() for (file <- filesMatching("src", _.endsWith(_)))
println(file) for (file <- filesEnding("src"))
println(file) } private def filesHere = (new File(".")).listFiles //matcher是传入一个函数,返回boolean值,比如_.endsWith(_)
private def filesMatching(query: String, matcher: (String, String) => Boolean) = {
for (file <- filesHere; if matcher(file.getName, query)) yield file
} //上面的函数不够简洁,下面是更加简洁的定义
private def filesMatch(matcher: String => Boolean) = {
for (file <- filesHere; if matcher(file.getName)) yield file
} //然后可以定义使用不同matcher()的方法
def filesEnding(query: String) = {
filesMatch(_.endsWith(query))
} //使用exists来简化代码
def containsOdd(nums: List[Int]): Boolean = {
nums.exists(_ % 2 == 1)
} def containsNeg(nums: List[Int]): Boolean = {
nums.exists(_ < 0)
} }

输出是

./.idea
./build.sbt
./target
./input
./project
./src ./src
./src

2.柯里化

//柯里化,可以看成是两个函数,y是第一个函数sum(x: Int)的参数
def sum(x: Int)(y: Int) = {
x + y
} //println(sum2(2))的输出是4
def sum2 = sum(2)_

3.继承

package com.scala.first

/**
* Created by common on 17-4-16.
*/
object AbstractClass { def main(args: Array[String]): Unit = {
val ae = new ArrayElement(Array("hello", "world"))
println(ae.width) val list1 = List(1,2,3,4)
val list2 = List(1,2,3,4,5)
//Scala中同时遍历两个list,如果长度不一样会截去
for((line1,line2) <- list1 zip list2){
println(line1+line2)
}
} } //定义一个抽象类
abstract class Element { //定义无参方法,抽象成员
def contents: Array[String] def height: Int = contents.length def width: Int = if (height == 0) 0 else contents(0).length } //扩展类,继承了上面的抽象类,需要实现抽象类中的方法
class ArrayElement(content: Array[String]) extends Element {
def contents: Array[String] = content
} //更加简洁的写法,contents和Element中的contents保持一致
class ArrayElement2(val contents: Array[String]) extends Element //另一个例子
class cat {
//确保一个成员不被子类重写,需要把其定义成final
// final val dangerous = false
val dangerous = false
} class tiger(override val dangerous: Boolean, private var age: Int) extends cat

4.特质

package com.scala.first

/**
* Created by common on 17-4-17.
*/
object Trait { def main(args: Array[String]): Unit = {
val person = new Person //变量an可以初始化为任何混入了特质的类的对象,person对象包含了Animal特质
val an: Animal = person
println(an.toString) val p = new PP()
//输出People特质中的内容
p.say() } } trait Animal { def run(): Unit = {
println("Animal can run")
}
} //具有特质Animal
class Person extends Animal {
override def toString = "can say"
} //具有特质Animal
class Tiger extends Animal {
override def toString = "can run fast"
} //一个类只能继承一个父类。但是能混入多个特质
//特征的作用:
//1.把胖接口转换成瘦接口
//2.为类提供可堆叠的改变
class Live trait HasLeg //注意不能给特质中传递任何的参数
class PersonTiger extends Live with Animal with HasLeg {
println("混入了多个特质")
} class P {
def say(): Unit = {
println("I am a people")
}
} //特质在抽象方法中的动态绑定
trait People extends P {
abstract override def say(): Unit = {
println("I am a trait people")
}
} class PP extends People{
//输出People特质中的内容
}

Scala学习笔记——简化代码、柯里化、继承、特质的更多相关文章

  1. 从0开始的Python学习007函数&函数柯里化

    简介 函数是可以重用的程序段.首先这段代码有一个名字,然后你可以在你的程序的任何地方使用这个名称来调用这个程序段.这个就是函数调用,在之前的学习中我们已经使用了很多的内置函数像type().range ...

  2. Scala基础:闭包、柯里化、隐式转换和隐式参数

    闭包,和js中的闭包一样,返回值依赖于声明在函数外部的一个或多个变量,那么这个函数就是闭包函数. val i: Int = 20 //函数func的方法体中使用了在func外部定义的变量 那func就 ...

  3. scala面向对象.高阶函数,柯里化,Actor编程简介

    1.定义一个类 class Person{ //用val修饰的变量是只读属性,有getter但是没有setter val id ="111" //用var修饰的变量既有getter ...

  4. Scala学习笔记(三)类层级和特质

    无参方法 功能:将方法的定义转换为属性字段的定义: 作用范围:方法中没有参数,并且方法仅能通过读取所包含的对象属性去访问可变状态,而不改变可变状态,就可使用无参方法: 例子: abstract cla ...

  5. (三十八)js之柯里化

    先给大家介绍什么是柯里化与反柯里化 百度翻译: 在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的 ...

  6. Scala学习笔记(七):Rational、隐式转换、偏函数、闭包、重复参数及柯里化

    class Rational(n: Int, d: Int) { require(d != 0) private val g: Int = gcd(n, d) val number: Int = n ...

  7. 【React】学习笔记(一)——React入门、面向组件编程、函数柯里化

    课程原视频:https://www.bilibili.com/video/BV1wy4y1D7JT?p=2&spm_id_from=pageDriver 目录 一.React 概述 1.1.R ...

  8. Scala学习之路 (七)Scala的柯里化及其应用

    一.概念 柯里化(currying, 以逻辑学家Haskell Brooks Curry的名字命名)指的是将原来接受两个参数的函数变成新的接受一个参数的函数的过程.新的函数返回一个以原有第二个参数作为 ...

  9. 大数据学习day17------第三阶段-----scala05------1.Akka RPC通信案例改造和部署在多台机器上 2. 柯里化方法 3. 隐式转换 4 scala的泛型

    1.Akka RPC通信案例改造和部署在多台机器上  1.1 Akka RPC通信案例的改造(主要是把一些参数不写是) Master package com._51doit.akka.rpc impo ...

随机推荐

  1. Bracket 使用指南

    Brackets 是一个免费.开源且跨平台的 HTML/CSS/JavaScript 前端 WEB 集成开发环境 (IDE工具).该项目由Adobe 创建和维护,根据MIT许可证发布,支持 Windo ...

  2. JVM加载class文件的原理机制(转)

    JVM加载class文件的原理机制 1.Java中的所有类,必须被装载到jvm中才能运行,这个装载工作是由jvm中的类装载器完成的,类装载器所做的工作实质是把类文件从硬盘读取到内存中 2.java中的 ...

  3. JavaScript:谈谈let和const

    最近接触到ES6的一些相关新特性,想借let和const两个命令谈谈JavaScript在变量方面的改进. 由于let和const有很多相似之处,我们就先说一说let吧. 1. let添加了块级作用域 ...

  4. eclipse如何导入jar包 BUILD PATH

    http://blog.csdn.net/believejava/article/details/41750987

  5. C#高级编程9 第18章 部署

    C#高级编程9 第18章 部署 使用 XCopy 进行部署 本主题演示如何通过将应用程序文件从一台计算机复制到另一台计算机来部署应用程序. 1.将项目中生成的程序集复制到目标计算机,生成的程序集位于项 ...

  6. android:ListView bbs Demo

    我们制 作的 message_left.9.png 可以作为收到消息的背景图,那么毫无疑问你还需要再制作一张 message_right.9.png 作为发出消息的背景图. 图片都提供好了之后就可以开 ...

  7. Knockout.Js官网学习(加载或保存JSON数据)

    前言 Knockout可以实现很复杂的客户端交互,但是几乎所有的web应用程序都要和服务器端交换数据(至少为了本地存储需要序列化数据),交换数据最方便的就是使用JSON格式 – 大多数的Ajax应用程 ...

  8. Spark:实现行转列

    示例JAVA代码: import static org.apache.spark.sql.functions.col; import static org.apache.spark.sql.funct ...

  9. Spark机器学习(5):SVM算法

    1. SVM基本知识 SVM(Support Vector Machine)是一个类分类器,能够将不同类的样本在样本空间中进行分隔,分隔使用的面叫做分隔超平面. 比如对于二维样本,分布在二维平面上,此 ...

  10. React 中 keys 的作用是什么?

    Keys 是 React 用于追踪哪些列表中元素被修改.被添加或者被移除的辅助标识. render () { return ( <ul> {this.state.todoItems.map ...