【Scala】 2. 函数

2. 函数

scala运算符、if ... else ...两部分和C语言类型,这里不再赘述,这里从for循环开始讲讲scala和c/c++的不同之处。

2.1 for循环

scala中主要包含to和until两个关键字,下面分别看看两者的用法,看例子就行了。

(1) to的用法

scala的例子使用to关键字如下:

scala 复制代码
var e = 0;  
for (e <- 0 to 5) {  
  println(f"e[$e%d] = " + (e + 1))  
}

打印出的结果如下:

shell 复制代码
e[0] = 1
e[1] = 2
e[2] = 3
e[3] = 4
e[4] = 5
e[5] = 6
(2) until的用法

scala的例子使用to关键字如下:

scala 复制代码
var e = 0;  
for (e <- 0 until 5) {  
  println(f"e[$e%d] = " + (e + 1))  
}

打印出的结果如下:

shell 复制代码
e[0] = 1
e[1] = 2
e[2] = 3
e[3] = 4
e[4] = 5

该结果和C语言中使用的方式是一致的。

2.2 函数

和c语言类似,基本可以作为参考,智能在于可以直接不写访问值和return关键字实现,下面举例说明。

(1)完整的实现方式
scala 复制代码
	// first way:  
	def sum(a: Int, b: Int): Int = {  
	    return (a+b)  
	}

包含return值和返回值类型

(2)不包含返回值类型
scala 复制代码
	// second way:  
	def sum(a: Int, b: Int): Int = {  
	    return a+b  
	}

包含return关键字

(3)不包含返回值类型和return关键字
scala 复制代码
	// third way:  
	def sum(a: Int, b: Int) = {  
		a+b  
	}

啥都省下来。

注:

  • 函数值包含缺省值,直接在变量后添加,举例如下:
scala 复制代码
	// third way:  
	def sum(a: Int, b: Int = 1) = {  
		a+b  
	}

此时调用时若需要采用缺省值,变量b可以不赋值。

scala 复制代码
	def main(args: Array[String]): Unit = {  
	  val a = 8;  
	  println(f"$a%d + 3 = " + sum(a))
	}
  • apply函数为一类特殊的函数,可在object和class中通过object名或class名的方式直接调用,举例如下:
scala 复制代码
object func {  
  def main(args: Array[String]): Unit = {  
	// 调用func object对象中的apply函数  
    func()  
  }  
  
  def apply() = {  
    println ("apply func test")  
  }
  • object对象中的main函数为scala语言中入口函数,即从此处开始运行。
相关推荐
apple_ttt8 小时前
从零开始讲PCIe(9)——PCIe总线体系结构
fpga开发·fpga·pcie
XiaoChaoZhiNeng1 天前
基于Zynq SDIO WiFi移植二(支持2.4/5G)
5g·fpga·zynq·sdio
apple_ttt1 天前
从零开始讲PCIe(6)——PCI-X概述
fpga开发·fpga·pcie
apple_ttt1 天前
从零开始讲PCIe(5)——66MHZ的PCI总线与其限制
fpga开发·fpga·pcie
诚实可靠小郎君95272 天前
FPGA IO延迟的约束与脚本
fpga开发·fpga·数字电路
日晨难再2 天前
AMBA:APB的历史(从APB1到APB5)
arm开发·arm·硬件工程·fpga·数字ic
辣个蓝人QEX3 天前
【FPGA开发】Xilinx FPGA差分输入时钟的使用方法
fpga开发·fpga·xilinx原语
隔着天花板看星星5 天前
SparkSQL-性能调优
大数据·分布式·sql·spark·scala
日晨难再5 天前
Verilog基础:$display系统函数和C语言中的库函数printf的区别
c语言·硬件工程·verilog·数字ic
武子康6 天前
大数据-156 Apache Druid 案例实战 Scala Kafka 订单统计
java·大数据·clickhouse·flink·kafka·scala·apache