https://developer.apple.com/library/content/documentation/Swift/Conceptual/Swift_Programming_Language/Functions.html
输入输出参数
函数参数默认为常量。尝试从该函数的主体内更改函数参数的值会导致编译时错误。这意味着您不能错误地更改参数的值。如果您希望函数修改参数的值,并且希望这些更改在函数调用结束后保持不变,请将该参数定义为 in-out 参数。
您可以通过将 inout 关键字放在参数类型之前来编写一个 in-out 参数。in-out 参数有一个值,该值被传入函数,被函数修改,并被传回函数以替换原始值。有关输入输出参数的行为和相关编译器优化的详细讨论,请参阅输入输出参数。
您只能将变量作为输入输出参数的参数传递。您不能将常量或文字值作为参数传递,因为无法修改常量和文字。当您将变量作为参数传递给 in-out 参数时,您可以在变量名称之前直接放置一个 & 符号,以表明它可以被函数修改。
笔记
输入输出参数不能有默认值,可变参数不能标记为输入输出。
下面是一个名为 swapTwoInts( : :) 的函数的示例,它有两个称为 a 和 b 的输入输出整数参数:
func swapTwoInts(_ a: inout Int, _ b: inout Int) {
let temporaryA = a
a = b
b = temporaryA
}
swapTwoInts( : :) 函数只是将 b 的值交换为 a,并将 a 的值交换为 b。该函数通过将 a 的值存储在名为temporaryA 的临时常量中,将b 的值分配给a,然后将temporaryA 分配给b 来执行此交换。
您可以使用两个 Int 类型的变量调用 swapTwoInts( : :) 函数来交换它们的值。请注意, someInt 和 anotherInt 的名称在传递给 swapTwoInts( : :) 函数时以 & 符号为前缀:
var someInt = 3
var anotherInt = 107
swapTwoInts(&someInt, &anotherInt)
print("someInt is now \(someInt), and anotherInt is now \(anotherInt)")
// Prints "someInt is now 107, and anotherInt is now 3"
上面的示例显示 someInt 和 anotherInt 的原始值被 swapTwoInts( : :) 函数修改,即使它们最初是在函数外部定义的。
笔记
输入输出参数与从函数返回值不同。上面的 swapTwoInts 示例没有定义返回类型或返回值,但它仍然修改了 someInt 和 anotherInt 的值。输入输出参数是函数在其函数体范围之外产生影响的另一种方式。