11_Scala函数柯理化惰性函数

1.函数柯里化

复制代码
    def test(a: Int, b: Int): Unit = {
      for (i <- 1 to a) println(i)
      for (i <- 1 to b) println(i)
    }

    var a = 10;
    var b = 100
    test(a, b)

2.构成柯里化

复制代码
**函数柯里化的做法,就是将无关的参数进行分离,可以设定多个参数列表;**
**修改上述test函数如下;**

but

--1.此方式赋值1个仅在给函数对象赋值时候传入即可

--2.柯里化运行的时候,只有两个函数都传入了,菜能执行:也就是说,只赋值1个的函数对象不能()运行,必须参数传够;

复制代码
    //    2.构成柯里化
    def test1(a: Int)( b: Int): Unit = {
      for (i <- 1 to a) println(i)
      for (i <- 1 to b) println(i)
    }

//    修改完成后可以调用一个参数
    val intToUnit:Int => Unit = test1(11)
    intToUnit(1)		//z=执行整体函数
    
    test1(10)(20)

3.递归函数

关于scala中的递归函数需要结果类型,不能让编译器自己推断

复制代码
   def test11(num:Int):Int={
      if (num<1) 1 else num*test11(num-1)
    }

小结:递归函数必须写上函数返回值;

4.惰性函数

惰性函数目的:提高代码效率;

lazy标记的函数表示惰性函数,不需要预先计算他们;

开发过程中,可以将运行复杂的函数标记为惰性函数;

复制代码
object LazyDemo {

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

    lazy val res = sum(10, 20) // lazy修饰,sum()函数不会被立即执行,要首次被调用之后再执行
    println("================")
    // println("res:"+res)
  }

  def sum(a: Int, b: Int): Int = {
    println("sum执行了")
    a + b
  }
}

object LazyDemo {

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

    lazy val res = sum(10, 20) // lazy修饰,sum()函数不会被立即执行,要首次被调用之后再执行
    println("================")
    println("res:" + res) //调用sum方法
  }

  def sum(a: Int, b: Int): Int = {
    println("sum执行了")
    a + b
  }
}

输出

复制代码
sum执行了
res:30
代码二:
相关推荐
草莓熊Lotso25 分钟前
C++ STL set 系列完全指南:从底层原理、核心接口到实战场景
开发语言·c++·人工智能·经验分享·网络协议·算法·dubbo
TG:@yunlaoda360 云老大26 分钟前
谷歌云Flink 核心组成及生态发展:实时数据处理的下一代引擎
大数据·flink·googlecloud
JavaBoy_XJ27 分钟前
电商系统中ES检索技术设计和运用
大数据·elasticsearch·搜索引擎
cheniie28 分钟前
python xmlrpc踩坑记录
python·踩坑·xmlrpc
咖啡の猫2 小时前
搭建Python开发环境
开发语言·python
程序猿小蒜3 小时前
基于springboot的共享汽车管理系统开发与设计
java·开发语言·spring boot·后端·spring·汽车
听风吟丶4 小时前
Java 8 Stream API 高级实战:从数据处理到性能优化的深度解析
开发语言·python
hygge9995 小时前
Spring Boot + MyBatis 整合与 MyBatis 原理全解析
java·开发语言·经验分享·spring boot·后端·mybatis
文人sec6 小时前
pytest1-接口自动化测试场景
软件测试·python·单元测试·pytest
Run_Teenage6 小时前
C++:智能指针的使用及其原理
开发语言·c++·算法