1.scala 函数定义

2.scala 高阶函数

3.匿名函数

4.柯里化

import scala.math._

/**
* @author xwolf
* @date 2017-04-24 9:57
* @since 1.8
*/
class Function {
// _ 将round 方法转化为函数
val cel = round _ def add(x:Int,y:Int) = x+y //函数
def f(x : => Int) = x.+(3) def m (r : => Double) = {
val rs=(Math.PI*r*r*0.5)
rs} //高阶函数
def a(s:(Int)=>Int,z:Int)= s(z)+this.f(z) //匿名函数定义
val minus = (m:Int) => m-1 // 柯里化函数定义
def ads(x:Int)=(y:Int) => x*y //阶乘 (递归实现)
def sm(x:Int):BigInt={
if (x==1 || x==0) 1
else sm(x-1)*x
} //阶乘 (reduceLeft 实现)
def rsm(x:Int):BigInt={
(1 to x).reduceLeft(_ * _)
} // 求数组的最大值
def max(ary :Array[Int]):Int={
ary.reduceLeft(_ max _)
} // 求数组的最大值
def getMax(ary :Array[Int]):Int={
//底层也是reduceLeft
ary.max
}
}

测试:

object FunctionTest {

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

    val function = new Function
val cel = function.cel(32)
println(cel)
val a = function.f(1)
println(a)
val b = function.add(12,32)
println(b)
val c = function.m(2.4)
println(c) val d = function.minus(3)
println(d)
//柯里化
val e = function.ads(2)(10)
println(e) val f = function.sm(5)
println(f) val f2 = function.rsm(5)
println(f2) val ary =Array(3,32,4,2,2)
val g =function.getMax(ary)
println(g) //高阶函数使用
val af = function.a(a=>4,3)
print(af)
} }

  

  

[scala] scala 函数 (⑦)的更多相关文章

  1. Scala 匿名函数

    Scala 中定义匿名函数的语法很简单,箭头左边是参数列表,右边是函数体. 使用匿名函数后,我们的代码变得更简洁了. 下面的表达式就定义了一个接受一个Int类型输入参数的匿名函数: var inc = ...

  2. scala匿名函数

    package com.ming.test import scala.math._ object AnonymousFunc { def valueAtOneQuarter(f:(Double)=&g ...

  3. Scala应用函数

    我们使用“_” 来代替单个的参数,实际上你也可以使用“_”来代替整个参数列表,比如说,你可以使用 print _ 来代替 println (_). someNumbers.foreach(printl ...

  4. Scala学习——函数高级操作

    scala函数高级操作 一.字符串高级操作 多行字符串和插值 package top.ruandb.scala.Course06 object StringApp { def main(args: A ...

  5. Scala学习——函数

    一.函数的定义(def) object FunctionApp { //定义函数:方法体内最后一行为返回值,不需要使用return def add(a:Int,b:Int):Int={ a + b } ...

  6. scala mapPartitionsWithIndex函数的使用

    var rdd1=sc.makeRDD(Array((1,"A"),(2,"B"),(3,"C"),(4,"D")),2 ...

  7. Scala的函数,高阶函数,隐式转换

    1.介绍 2.函数值复制给变量 3.案例 在前面的博客中,可以看到这个案例,关于函数的讲解的位置,缺省. 4.简单的匿名函数 5.将函数做为参数传递给另一个函数 6.函数作为输出值 7.类型推断 8. ...

  8. Scala(二) —— 函数

    try 表达式 var result = try{ Integer.parseInt("dog") }catch{ case _ => 0 }finally{ println ...

  9. scala中函数简单使用记录

    object funcHighLevel { def main(args: Array[String]): Unit = { // 创建一个匿名函数 val sayFunc = (name: Stri ...

随机推荐

  1. PHP——大话PHP设计模式——基本设计模式(工厂模式、单例模式、注册器模式)

  2. CSS 自适应

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  3. linux软件管理(六)

    [教程主题]:linux软件管理 [1]软件包管理 在系统管理中,软件包的管理是最重要的,是系统管理的基础的基础, 只有我们学会软件包的管理才能谈得上其它的应用. RPM RPM是软件管理程序,提供软 ...

  4. hbase 学习(十二)非mapreduce生成Hfile,然后导入hbase当中

    最近一个群友的boss让研究hbase,让hbase的入库速度达到5w+/s,这可愁死了,4台个人电脑组成的集群,多线程入库调了好久,速度也才1w左右,都没有达到理想的那种速度,然后就想到了这种方式, ...

  5. [hadoop读书笔记] Hadoop下各技术应用场景

    1.数据采集 对于数据采集主要分为三类,即结构化数据库采集,日志和文件采集,网页采集. 对于结构化数据库,采用Sqoop是合适的,可以实现结构化数据库中数据并行批量入库到hdfs存储.对于网页采集,前 ...

  6. C++ vector清空元素的三种方法

    #include <iostream> #include <vector> using namespace std; //STL vector的几种清空容器(删除)办法 voi ...

  7. How to deal with "Could not find component on update server. Contact VMware Support or your system administrator." in Vmware.

    手动将vmware安装目录下的vmtools镜像文件,windows.iso文件放到虚拟机的光区里. 再进入虚拟机的系统,在系统里打开光盘进行安装

  8. nextcloud私有云盘的部署

    nextcloud在centos系统下搭建自己的私有云盘 搭建一套自己的私有云盘,让数据存储更加方便.可靠.自己搭建的云存储,首先没有什么容量.下载速度的限制,而且本地访问速度很快.一开始以为Next ...

  9. Java相对路径/绝对路径总结

    Version:0.9 StartHTML:-1 EndHTML:-1 StartFragment:00000099 EndFragment:00019826 Java相对路径/绝对路径总结(2) 修 ...

  10. Android  <meta-data>

    在AndroidManifest.xml中,<meta-data>元素可以作为子元素,被包含在<activity>.<application>.<servic ...