【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语言中入口函数,即从此处开始运行。
相关推荐
热爱学习地派大星5 天前
Xilinx FPGA功耗评估
fpga开发·verilog·vivado·fpga功耗·xpe
进击的奶龙5 天前
21verilog函数
verilog·基础语法
linweidong16 天前
一站式用AI编程神奇Cursor/Trae(VScode环境)开发运行Scala应用
大数据·vscode·后端·大模型·scala·ai编程·cursor
XINVRY-FPGA17 天前
XCVU47P-2FSVH2892E Xilinx Virtex UltraScale+ FPGA AMD
c语言·c++·人工智能·嵌入式硬件·阿里云·fpga开发·fpga
迎风打盹儿20 天前
FPGA点亮ILI9488驱动的SPI+RGB接口LCD显示屏(二)
fpga·verilog hdl·ili9488·rgb接口·lcd显示屏
tiantianuser24 天前
RDMA简介7之RoCE v2可靠传输
服务器·fpga开发·verilog·xilinx·rdma·可编程逻辑
白总Server24 天前
GaussDB 分布式数据库调优(架构到全链路优化)
java·网络·c++·架构·go·scala·数据库架构
小伍_Five25 天前
spark数据处理练习题番外篇【下】
java·大数据·spark·scala
无人赴约的cat1 个月前
【20250607接单】Spark + Scala + IntelliJ 项目的开发环境配置从零教学
大数据·spark·scala
小伍_Five1 个月前
spark数据处理练习题番外篇【上】
java·大数据·spark·scala