2.2 函数的参数与返回值

在上一个小结里面,我们实现了一个只能计算固定半径圆面积的函数。这一节我们需要对它进行改进。在此之前 我们还是要讨论一下微波炉的事情,我们在使用微波炉之前,我们会针对不同的食物,设定不同的温度和加热时间,微波炉接收我们的设定,并按照这些设定进行工作。正是因为微波炉具有这种“交互”的能力,所以才能让微波炉的应用更加广泛。其实我们也希望calArea能够根据我们的设定而进行计算,

1、函数的参数

函数和微波炉的工作方式类似,可以通过接受参数的方式来允许我们对其工作进行设定。在前面我们看到了函数名后面的(),其实它就是用来传递参数的地方。我们之前的函数是这样定义的。

func calArea() {
   var radius = 2.5
   let pi = 3.14
   var area = radius * radius * pi
   print(area)  
}

我们现在来改变它,让它可以支持参数。参数定义在括号里,首先是参数名称,然后是用冒号分隔的参数类型。凡是swift认可的类型基本都可以做为函数的参数进行传递,这包括我们已经了解的基本类型(Int,String,Bool等等)、集合类型,甚至函数类型都可以。

func calArea(radius: Double) {
   let pi = 3.14
   var area = radius * radius * pi
   print(area)      
}

有了参数的帮忙,我们可以在函数的代码体内直接使用该参数进行计算了,现在我们可以方便计算任意圆的半径了。我们只需要将需要计算的半径,放在()中传递给calArea就可以完成函数调用了。例如我们可以分别计算半径为3.5、4.7的圆的面积。

calArea(3.5)
calArea(4.7)

可是这时又有了新的需求,在计算面积的时候,有时我们感觉 pi = 3.14 这个精度不够,我们需要调整精度,但是目前calArea并没有让我们调整精度的办法。现在我们再来调整一下。

func calArea(radius: Double,pi: Double) {
   var area = radius * radius * pi
   print(area)      
}

我们给calArea增加了新的参数pi,定义方式与参数radius的方式相同,两个参数之间用逗号分隔。理论上函数没有限制参数的数量,我们可以给函数传递多个参数,但是考虑到调参数过多会造成调用者难以理解的问题,我们应该尽量控制参数的个数。

在函数的调用上,第一个参数与第二参数受到了区别的对待(swift3之后,就不存在这种区别了)。swift默认会默认省略第一个参数名(外部参数名)。

calArea(3.5,pi: 3.1415) //  使用更高的精度计算 半径为 3.5的圆的面积

我们会发现,第二个参数使用了 pi: 进行标示,而第一个参数确没有,我们将在另外一个内容里面介绍这个原因。

2、函数的返回值

目前calArea已经可以针对不同的精度,对不同的半径进行计算了,但是函数只是把计算结果简单打印一下就丢弃了。我们现在需要从calArea获得计算的结果,就像下面这样:

var area = calArea(3.5,pi: 3.1415)
print(area)

很明显calArea还不能满足这样的需求,因为它目前什么也没有返回。在函数的定义时,我们不但可以指定参数,还可以为函数指定返回值。我们可以把参数理解为函数的输入,而返回值理解为函数的输出,我们也可以用这样的角度来看待函数:函数就是用自己的内部逻辑对输入进行处理,然后得到一个返回值。

func name() -> String {
    return "Hello,world"
}

在定义是,我们需要明确函数返回值的类型 -> String,目前我们了解过的所有类型都可以用作函数的返回值类型定义。那我们现在来为我们的calArea函数定义返回值。我们需要的是一个Double类型的返回值。

func calArea(radius: Double,pi: Double) -> Double {
   let area = radius * radius * pi
   return area      
}

我们给calArea增加了一个Double类型的返回值的定义,并使用了return语句,明确要返回的内容。现在我们可以获得计算后的结果了。

var area = calArea(3.5,pi: 3.1415)
print(area)

你可能感兴趣的:(2.2 函数的参数与返回值)