about_Return
简短说明
退出当前作用域,它可以是函数、脚本或脚本块。
长说明
关键字 (keyword) return
退出函数、脚本或脚本块。 它可用于在特定点退出范围、返回值或指示已到达范围的末尾。
熟悉 C 或 C# 等语言的用户可能希望使用return
关键字 (keyword) 来明确保留作用域的逻辑。
在 PowerShell 中,即使没有包含 Return 关键字 (keyword) 的语句,每个语句的结果也会作为输出返回。 C 或 C# 等语言仅返回由return
关键字 (keyword) 指定的值。
注意
从 PowerShell 5.0 开始,PowerShell 添加了使用正式语法定义类的语言。 在 PowerShell 类的上下文中,除使用 return
语句指定的内容外,方法不会输出任何内容。 可以在 about_Classes 中详细了解 PowerShell 类。
语法
关键字 (keyword) 的return
语法如下:
return [<expression>]
return
关键字 (keyword) 可以单独显示,也可以后跟值或表达式,如下所示:
return
return $a
return (2 + $a)
示例
以下示例使用 return
关键字 (keyword) 在满足条件时在特定点退出函数。 奇数不乘以,因为 return 语句先退出该语句才能执行。
function MultiplyEven
{
param($number)
if ($number % 2) { return "$number is not even" }
$number * 2
}
1..10 | ForEach-Object {MultiplyEven -Number $_}
1 is not even
4
3 is not even
8
5 is not even
12
7 is not even
16
9 is not even
20
在 PowerShell 中,即使不使用关键字 (keyword) ,return
也可以返回值。
返回每个语句的结果。 例如,以下语句返回 变量的值 $a
:
$a
return
以下语句还返回 的值 $a
:
return $a
以下示例包含一个语句,旨在让用户知道函数正在执行计算:
function calculation {
param ($value)
"Please wait. Working on calculation..."
$value += 73
return $value
}
$a = calculation 14
“请稍候。 正在处理计算...”不显示字符串。 而是将其 $a
分配给 变量,如以下示例所示:
PS> $a
Please wait. Working on calculation...
87
信息字符串和计算结果均由 函数返回并分配给 $a
变量。
若要在函数中显示消息(从 PowerShell 5.0 开始),可以使用 Information
流。 下面的代码使用 cmdlet 更正了上述示例,Write-Information
而 cmdlet 的 为 InformationAction
Continue。
function calculation {
param ($value)
Write-Information "Please wait. Working on calculation..." -InformationAction Continue
$value += 73
return $value
}
$a = calculation 14
Please wait. Working on calculation...
C:\PS> $a
87
返回值和管道
从脚本块或函数返回集合时,PowerShell 会自动展开成员,并通过管道一次传递一个成员。 这是由于 PowerShell 的一次处理。 有关详细信息,请参阅 about_pipelines。
以下返回数字数组的示例函数说明了此概念。 函数的输出通过管道传递给 cmdlet, Measure-Object
该 cmdlet 对管道中的对象数进行计数。
function Test-Return
{
$array = 1,2,3
return $array
}
Test-Return | Measure-Object
Count : 3
Average :
Sum :
Maximum :
Minimum :
Property :
若要强制脚本块或函数将集合作为单个对象返回到管道,请使用以下两种方法之一:
一元数组表达式
利用一元表达式,可以将返回值作为单个对象向下发送,如以下示例所示。
function Test-Return { $array = 1,2,3 return (, $array) } Test-Return | Measure-Object
Count : 1 Average : Sum : Maximum : Minimum : Property :
Write-Output
具有 NoEnumerate 参数。还可以将
Write-Output
cmdlet 与 NoEnumerate 参数一起使用。 以下示例使用Measure-Object
cmdlet 对关键字 (keyword) 从示例函数发送到管道的对象return
进行计数。function Test-Return { $array = 1, 2, 3 return Write-Output -NoEnumerate $array } Test-Return | Measure-Object
Count : 1 Average : Sum : Maximum : Minimum : Property :