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
代码二:
相关推荐
Haoea!5 分钟前
jkd8特性
开发语言
Acrel1500035313820 分钟前
重构能源管理:Acrel EMS 3.0 让降本增效成为底层逻辑
大数据·人工智能
测试199821 分钟前
软件测试之压力测试
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·压力测试
Swizard25 分钟前
极限瘦身:将 Python AI 应用从 100MB 砍到 30MB
java·python·ai·移动开发
编织幻境的妖31 分钟前
Python代码性能优化工具与方法
开发语言·python·性能优化
Fcy64833 分钟前
二叉搜索树(C++实现)
开发语言·数据结构·c++·二叉搜索树
金融小师妹37 分钟前
黄金上探4260后基于阻力位识别模型回落,本周聚焦美联储决议的LSTM-NLP联合预测
大数据·人工智能·深度学习
程序员-周李斌42 分钟前
ArrayBlockingQueue 源码解析
java·开发语言·后端·哈希算法·散列表
Rookie_JE1 小时前
python docxtpl库学习
python
我不是小upper1 小时前
CNN+BiLSTM !!最强序列建模组合!!!
人工智能·python·深度学习·神经网络·cnn