15、swift开发iOS——函数

前端之家收集整理的这篇文章主要介绍了15、swift开发iOS——函数前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

Swift 函数@H_301_5@

Swift 函数用来完成特定任务的独立的代码块。@H_301_5@

Swift使用一个统一的语法来表示简单的C语言风格的函数到复杂的Objective-C语言风格的方法@H_301_5@

函数声明: 告诉编译器函数的名字,返回类型及参数。@H_301_5@

函数定义: 提供了函数的实体。@H_301_5@

Swift 函数包含了参数类型及返回值类型:@H_301_5@

函数定义@H_301_5@

Swift 定义函数使用关键字 func@H_301_5@

定义函数的时候,可以指定一个或多个输入参数和一个返回值类型。@H_301_5@

每个函数都有一个函数名来描述它的功能。通过函数名以及对应类型的参数值来调用这个函数函数的参数传递的顺序必须与参数列表相同。@H_301_5@

函数的实参传递的顺序必须与形参列表相同,-> 后定义函数的返回值类型。@H_301_5@

语法@H_301_5@

func funcname(形参) -> returntype@H_301_5@

{@H_301_5@

Statement1@H_301_5@

Statement2@H_301_5@

……@H_301_5@

Statement N@H_301_5@

return parameters@H_301_5@

}@H_301_5@

实例@H_301_5@

以下我们定义了一个函数名为 runoob 的函数,形参的数据类型为 String,返回值也为 String:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func runoob(site: String) -> String {@H_301_5@

return site@H_301_5@

}@H_301_5@

print(runoob(site: "www..com"))@H_301_5@


@H_301_5@

函数调用@H_301_5@

我们可以通过函数名以及对应类型的参数值来调用函数函数的参数传递的顺序必须与参数列表相同。@H_301_5@

函数参数@H_301_5@

函数可以接受一个或者多个参数,我们也可以使用元组(tuple)向函数传递一个或多个参数:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func mult(no1: Int,no2: Int) -> Int {@H_301_5@

return no1*no2@H_301_5@

}@H_301_5@

print(mult(no1: 2,no2:20))@H_301_5@

print(mult(no1: 3,no2:15))@H_301_5@

print(mult(no1: 4,no2:30))@H_301_5@

以上程序执行输出结果为:@H_301_5@

40@H_301_5@

45@H_301_5@

120@H_301_5@

不带参数函数@H_301_5@

我们可以创建不带参数的函数@H_301_5@

语法:@H_301_5@

func funcname() -> datatype {@H_301_5@

return datatype@H_301_5@

}@H_301_5@

实例@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func sitename() -> String {@H_301_5@

return "教程"@H_301_5@

}@H_301_5@

print(sitename())@H_301_5@


@H_301_5@

元组作为函数返回值@H_301_5@

函数返回值类型可以是字符串,整型,浮点型等。@H_301_5@

元组与数组类似,不同的是,元组中的元素可以是任意类型,使用的是圆括号。@H_301_5@

你可以用元组(tuple)类型让多个值作为一个复合值从函数中返回。@H_301_5@

下面的这个例子中,定义了一个名为minMax(_:)的函数,作用是在一个Int数组中找出最小值与最大值。@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func minMax(array: [Int]) -> (min: Int,max: Int) {@H_301_5@

var currentMin = array[0]@H_301_5@

var currentMax = array[0]@H_301_5@

for value in array[1..<array.count] {@H_301_5@

if value < currentMin {@H_301_5@

currentMin = value@H_301_5@

} else if value > currentMax {@H_301_5@

currentMax = value@H_301_5@

}@H_301_5@

}@H_301_5@

return (currentMin,currentMax)@H_301_5@

}@H_301_5@


@H_301_5@

let bounds = minMax(array: [8,-6,2,109,3,71])@H_301_5@

print("最小值为 \(bounds.min) ,最大值为 \(bounds.max)”)@H_301_5@


@H_301_5@

minMax(_:)函数返回一个包含两个Int值的元组,这些值被标记为min和max,以便查询函数的返回值时可以通过名字访问它们。@H_301_5@

以上程序执行输出结果为:@H_301_5@

最小值为 -6 ,最大值为 109@H_301_5@

如果你不确定返回的元组一定不为nil,那么你可以返回一个可选的元组类型。@H_301_5@

你可以通过在元组类型的右括号后放置一个问号来定义一个可选元组,例如(Int,Int)?或(String,Int,Bool)?@H_301_5@

注意@H_301_5@

可选元组类型如(Int,Int)?与元组包含可选类型如(Int?,Int?)是不同的.可选的元组类型,整个元组是可选的,而不只是元组中的每个元素值。@H_301_5@

前面的minMax(_:)函数返回了一个包含两个Int值的元组。但是函数不会对传入的数组执行任何安全检查,如果array参数是一个空数组,如上定义的minMax(_:)在试图访问array[0]时会触发一个运行时错误@H_301_5@

为了安全地处理这个"空数组"问题,将minMax(_:)函数改写为使用可选元组返回类型,并且当数组为空时返回nil:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func minMax(array: [Int]) -> (min: Int,max: Int)? {@H_301_5@

if array.isEmpty { return nil }@H_301_5@

var currentMin = array[0]@H_301_5@

var currentMax = array[0]@H_301_5@

for value in array[1..<array.count] {@H_301_5@

if value < currentMin {@H_301_5@

currentMin = value@H_301_5@

} else if value > currentMax {@H_301_5@

currentMax = value@H_301_5@

}@H_301_5@

}@H_301_5@

return (currentMin,currentMax)@H_301_5@

}@H_301_5@

if let bounds = minMax(array: [8,71]) {@H_301_5@

print("最小值为 \(bounds.min),组大值为 \(bounds.max)")@H_301_5@

}@H_301_5@

以上程序执行输出结果为:@H_301_5@

最小值为 -6,组大值为 109@H_301_5@

函数参数名称@H_301_5@

函数参数都有一个外部参数名和一个局部参数名。@H_301_5@

局部参数名@H_301_5@

局部参数名在函数的实现内部使用。@H_301_5@

func sample(number: Int) {@H_301_5@

println(number)@H_301_5@

}@H_301_5@

以上实例中 number 为局部参数名,只能在函数体内使用。@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func sample(number: Int) {@H_301_5@

print(number)@H_301_5@

}@H_301_5@

sample(number: 1)@H_301_5@

sample(number: 2)@H_301_5@

sample(number: 3)@H_301_5@


@H_301_5@

外部参数名@H_301_5@

你可以在局部参数名前指定外部参数名,中间以空格分隔,外部参数名用于在函数调用时传递给函数的参数。@H_301_5@

如下你可以定义以下两个函数参数名并调用它:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func pow(firstArg a: Int,secondArg b: Int) -> Int {@H_301_5@

var res = a@H_301_5@

for _ in 1..<b {@H_301_5@

res = res * a@H_301_5@

}@H_301_5@

print(res)@H_301_5@

return res@H_301_5@

}@H_301_5@

pow(firstArg:5,secondArg:3)@H_301_5@

以上程序执行输出结果为:@H_301_5@

125@H_301_5@

注意@H_301_5@

如果你提供了外部参数名,那么函数在被调用时,必须使用外部参数名。@H_301_5@

可变参数@H_301_5@

可变参数可以接受零个或多个值。函数调用时,你可以用可变参数来指定函数参数,其数量是不确定的。@H_301_5@

可变参数通过在变量类型名后面加入(...)的方式来定义。@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func vari<N>(members: N...){@H_301_5@

for i in members {@H_301_5@

print(i)@H_301_5@

}@H_301_5@

}@H_301_5@

vari(members: 4,5)@H_301_5@

vari(members: 4.5,3.1,5.6)@H_301_5@

vari(members: "Google","Baidu","Runoob")@H_301_5@


@H_301_5@

常量,变量及 I/O 参数@H_301_5@

一般默认在函数中定义的参数都是常量参数,也就是这个参数你只可以查询使用,不能改变它的值。@H_301_5@

如果想要声明一个变量参数,可以在前面加上var,这样就可以改变这个参数的值了。@H_301_5@

例如:@H_301_5@

func getName(var id:String).........@H_301_5@

此时这个id值可以在函数中改变。@H_301_5@

一般默认的参数传递都是传值调用的,而不是传引用。 所以传入的参数在函数内改变,并不影响原来的那个参数。传入的只是这个参数的副本。@H_301_5@

变量参数,正如上面所述,仅仅能在函数体内被更改。如果你想要一个函数可以修改参数的值,并且想要在这些修改函数调用结束后仍然存在,那么就应该把这个参数定义为输入输出参数(In-Out Parameters)。@H_301_5@

定义一个输入输出参数时,在参数定义前加 inout 关键字。一个输入输出参数有传入函数的值,这个值被函数修改,然后被传出函数,替换原来的值。@H_301_5@

实例@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func swapTwoInts(var a:Int,var b:Int){@H_301_5@

@H_301_5@

let t = a@H_301_5@

a = b@H_301_5@

b = t@H_301_5@

}@H_301_5@


@H_301_5@

var x = 0,y = 100@H_301_5@

print("x = \(x) ;y = \(y)")@H_301_5@


@H_301_5@

swapTwoInts(x,b:y)@H_301_5@

print("x = \(x) ;y = \(y)")@H_301_5@

以上程序执行输出结果为:@H_301_5@

x = 0 ;y = 100@H_301_5@

x = 0 ;y = 100@H_301_5@

修改方法是使用inout关键字:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func swapTwoInts( a:inout Int,b:inout Int){@H_301_5@

@H_301_5@

let t = a@H_301_5@

a = b@H_301_5@

b = t@H_301_5@

}@H_301_5@


@H_301_5@

var x = 0,y = 100@H_301_5@

print("x = \(x) ;y = \(y)")@H_301_5@


@H_301_5@

swapTwoInts(a: &x,b:&y)@H_301_5@

print("x = \(x) ;y = \(y)")@H_301_5@

以上程序执行输出结果为:@H_301_5@

x = 0 ;y = 100@H_301_5@

x = 100 ;y = 0@H_301_5@

函数类型及使用@H_301_5@

每个函数都有种特定的函数类型,由函数的参数类型和返回类型组成。@H_301_5@

func inputs(no1: Int,no2: Int) -> Int {@H_301_5@

return no1/no2@H_301_5@

}@H_301_5@

实例如下:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func inputs(no1: Int,no2: Int) -> Int {@H_301_5@

return no1/no2@H_301_5@

}@H_301_5@

print(inputs(no1: 20,no2:10))@H_301_5@

print(inputs(no1: 36,no2:6))@H_301_5@

以上程序执行输出结果为:@H_301_5@

2@H_301_5@

6@H_301_5@

以上函数定义了两个 Int 参数类型,返回值也为 Int 类型。@H_301_5@

接下来我们看下如下函数函数定义了参数为 String 类型,返回值为 String 类型。@H_301_5@

Func inputstr(name: String) -> String {@H_301_5@

return name@H_301_5@

}@H_301_5@

函数也可以定义任何参数及类型,如下所示:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func inputstr() {@H_301_5@

print("教程")@H_301_5@

print("www.baidu.com")@H_301_5@

}@H_301_5@

inputstr()@H_301_5@


@H_301_5@

使用函数类型@H_301_5@

在 Swift 中,使用函数类型就像使用其他类型一样。例如,你可以定义一个类型为函数的常量或变量,并将适当的函数赋值给它:@H_301_5@

var addition: (Int,Int) -> Int = sum@H_301_5@

解析:@H_301_5@

"定义一个叫做 addition 的变量,参数与返回值类型均是 Int ,并让这个新变量指向 sum 函数"。@H_301_5@

sum 和 addition 有同样的类型,所以以上操作是合法的。@H_301_5@

现在,你可以用 addition 来调用被赋值的函数了:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func sum(a: Int,b: Int) -> Int {@H_301_5@

return a + b@H_301_5@

}@H_301_5@

var addition: (Int,Int) -> Int = sum@H_301_5@

print("输出结果: \(addition(40,89))")@H_301_5@

以上程序执行输出结果为:@H_301_5@

输出结果: 129@H_301_5@

函数类型作为参数类型、函数类型作为返回类型@H_301_5@

我们可以将函数作为参数传递给另外一个参数:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func sum(a: Int,b: Int) -> Int {@H_301_5@

return a + b@H_301_5@

}@H_301_5@

var addition: (Int,89))")@H_301_5@


@H_301_5@

func another(addition: (Int,Int) -> Int,a: Int,b: Int) {@H_301_5@

print("输出结果: \(addition(a,b))")@H_301_5@

}@H_301_5@

another(addition: sum,a: 10,b: 20)@H_301_5@

以上程序执行输出结果为:@H_301_5@

输出结果: 129@H_301_5@

输出结果: 30@H_301_5@

函数嵌套@H_301_5@

函数嵌套指的是函数内定义一个新的函数,外部的函数可以调用函数内定义的函数@H_301_5@

实例如下:@H_301_5@

import Cocoa@H_301_5@


@H_301_5@

func calcDecrement(forDecrement total: Int) -> () -> Int {@H_301_5@

var overallDecrement = 0@H_301_5@

func decrementer() -> Int {@H_301_5@

overallDecrement -= total@H_301_5@

return overallDecrement@H_301_5@

}@H_301_5@

return decrementer@H_301_5@

}@H_301_5@

let decrem = calcDecrement(forDecrement: 30)@H_301_5@

print(decrem())@H_301_5@

以上程序执行输出结果为:@H_301_5@

-30@H_301_5@

猜你在找的Swift相关文章