Scala的高级特性

Scala的高级特性

☀小白的Scala学习笔记

目录

Scala的高级特性

1.匿名函数

2.如何把方法转化为函数

3.柯里化

1)柯里化

2)实例

3)柯里化应用:排序

[4)练习 Tea](#4)练习 Tea)


1.匿名函数

Scala 中的匿名函数是一种没有命名的函数,通常用于在代码中定义和传递简单的功能逻辑。匿名函数在 Scala 中被称为函数字面量(function literals),它的语法非常简洁和灵活。

下面是一个简单的 Scala 匿名函数的例子:

Scala 复制代码
// 定义一个接受两个整数参数并返回它们之和的普通函数
def add(x: Int, y: Int): Int = x + y

// 使用匿名函数实现相同的功能
val addFunction = (x: Int, y: Int) => x + y

// 在调用时,可以直接传递参数并调用匿名函数
val result = addFunction(3, 5)
println(result) // 输出: 8

在这个例子中,我们通过 val addFunction = (x: Int, y: Int) => x + y 的方式定义了一个匿名函数,它接受两个整数参数 xy,并返回它们的和。在调用时,我们直接使用 addFunction(3, 5) 进行调用,并将结果打印出来。

匿名函数在 Scala 中非常常见,特别是在函数式编程中经常用于传递逻辑给高阶函数(higher-order functions)或者在需要临时定义函数的场景下使用。它的灵活性和简洁性使得代码更加清晰和易于理解。

2.如何把方法转化为函数

在 Scala 中,可以使用 _操作符来将方法转换为函数。

注:下划线前有空格

Scala 复制代码
package com.oracle.jtxy

object Test2 {
  // 定义一个普通的方法
  def greet(name: String): String = {
    s"Hello, $name!"
  }
  def main(args: Array[String]): Unit = {
    // 使用下划线将方法转化为函数
    val greetFunction = greet _

    // 调用函数
    val result = greetFunction("Alice")
    println(result) // 输出: Hello, Alice!

  }
}
Scala 复制代码
package com.oracle.jtxy

object Test3 {
  // 定义一个普通的方法
  def double(x: Int): Int = x * 2

  def main(args: Array[String]): Unit = {
    // 使用`_`操作符将方法转化为函数
    val doubleFunction = double _

    // 调用函数
    val result = doubleFunction(5)
    println(result) // 输出: 10
  }
}

3.柯里化

1)柯里化

柯里化:在传递参数时可以分为多个括号来传递

Scala 复制代码
package com.oracle.jtxy

object Test1 {
  def add(a:Int)(b:Int)=a+b
  def main(args: Array[String]): Unit = {
    //柯里化:在传递参数时可以分为多个括号来传递
    val i = add(12)(24)
    println(i)
  }

}

那么 我们可能会说它有些多余 不过后面我们很快就能见到它的效果啦

2)实例

假设现在我们有一个方法 求 a+b 但是我现在想要在调用时 只传入一个参数 a

b 给一个默认值 变成隐式参数

Scala 复制代码
package com.oracle.jtxy

object Test1 {
  implicit val c:Int=3
  def add(a:Int)(implicit b:Int)={
    a+b
  }
  //b给一个默认值 调用的时候不需要传递 把参数变成隐式参数
  //当我们使用柯里化后 如果有参数是隐式的话 Scala会自动在上下文中搜索对应类型的变量
  def main(args: Array[String]): Unit = {
    //柯里化:在传递参数时可以分为多个括号来传递
    val i = add(12)
    println(i)
  }

}

3)柯里化应用:排序

1.通过隐式变量实现(Ordering)

Scala 复制代码
package com.oracle.jtxy

object Test4 {
  //ord 对象 能指导两个变量的大小
    //通过隐式变量实现


  implicit val ord=new Ordering[Stu](){
    override def compare(x: Stu, y: Stu): Int = x.sage - y.sage
  }

  case class Stu(sname:String,ssex:String,sage:Int)
  def main(args: Array[String]): Unit = {
    val list=List(Stu("zhangsan1","nan",21),Stu("zhangsan2","nan",11),Stu("zhangsan3","nan",16),Stu("zhangsan4","nan",33))
    val res=list.sortBy(x=>x)
    println(res)

  }

}

2.通过隐式转换实现(Ordered)

Scala 复制代码
package com.oracle.jtxy

object Test4 {
  //隐式转换 定义的是隐式的方法
  implicit def toStu(s:Stu)=new Ordered[Stu]{
    override def compare(that: Stu): Int = s.sage - that.sage
  }

  case class Stu(sname:String,ssex:String,sage:Int)
  def main(args: Array[String]): Unit = {
    val list=List(Stu("zhangsan1","nan",21),Stu("zhangsan2","nan",11),Stu("zhangsan3","nan",16),Stu("zhangsan4","nan",33))
    val res=list.sortBy(x=>x)
    println(res)

  }

}

4)练习 Tea

1.通过隐式变量实现

Scala 复制代码
package com.oracle.jtxy

import scala.collection.mutable.ArrayBuffer

object Test5 {
  //通过隐式变量实现
  implicit val ord=new Ordering[Tea](){
    override def compare(x: Tea, y: Tea): Int = x.tage - y.tage
  }

  case class Tea(tname:String,tsex:String,tage:Int)//样例类
  def main(args: Array[String]): Unit = {
    val array=new ArrayBuffer[Tea]()
    array.append(Tea("wangwu","nan",23),Tea("lisi","nv",45),Tea("maliu","nan",65),Tea("mazi","nan",28))
    val teas = array.sortBy(x => x)
    println(teas)
  }

}

2.通过隐式转换实现

Scala 复制代码
package com.oracle.jtxy

import scala.collection.mutable.ArrayBuffer

object Test5 {
  //通过隐式变量实现
  implicit def toTea(t:Tea)=new Ordered[Tea]{
    override def compare(that: Tea): Int = t.tage - that.tage
  }

  case class Tea(tname:String,tsex:String,tage:Int)//样例类
  def main(args: Array[String]): Unit = {
    val array=new ArrayBuffer[Tea]()
    array.append(Tea("wangwu","nan",23),Tea("lisi","nv",45),Tea("maliu","nan",65),Tea("mazi","nan",28))
    val teas = array.sortBy(x => x)
    println(teas)
  }

}
相关推荐
fire-flyer10 分钟前
设计模式之观察者模式
java·开发语言
倚栏听风雨17 分钟前
git "base点"详解,顺便解释merge和rebase区别
后端
咬_咬24 分钟前
C++仿muduo库高并发服务器项目:Poller模块
服务器·开发语言·c++·epoll·muduo
掘金一周39 分钟前
重新思考 weapp-tailwindcss 的未来 | 掘金一周 11.13
前端·人工智能·后端
Highcharts.js1 小时前
在Python中配置高度交互的数据可视化:Highcharts完全指南
开发语言·python·信息可视化·highcharts
小生凡一1 小时前
图解|Go语言实现 Agent|LLM+MCP+RAG
开发语言·后端·golang
l0sgAi1 小时前
SpringAI 整合MCP实现联网搜索 (基于tavily)
java·后端
朝新_1 小时前
【统一功能处理】从入门到源码:拦截器学习指南(含适配器模式深度解读)
数据库·后端·mybatis·适配器模式·javaee
思茂信息1 小时前
CST电动车EMC仿真(二)——电机控制器MCU的EMC仿真
开发语言·javascript·单片机·嵌入式硬件·cst·电磁仿真
q***7481 小时前
私有化部署DeepSeek并SpringBoot集成使用(附UI界面使用教程-支持语音、图片)
spring boot·后端·ui