PowerShell转换为无效并返回值

时间:2019-08-31 16:34:49

标签: powershell null void

我有一个运行一些代码的函数,如果成功则返回$ True,否则返回$ False。

作为功能代码的一部分,我使用此命令将一些cmdlet的结果强制转换为[void]

function New-SampleFunction
{
    [void]::('2');

     return $true
}

[bool]$myReturnValuen = New-SampleFunction

# This results in exception
The above will result in a Cannot convert value "System.Object[]" to type "System.Boolean". Boolean parameters accept only Boolean values and numbers, such as $True, $False, 1 or 0.

当然,如果我让PowerShell推断函数返回值中的类型,这将起作用,但是有趣的部分是我检查变量的内容

function New-SampleFunction
{
    [void]::('2')

     return $true
}

$myReturnValuen = New-SampleFunction


$returnValue.GetType()

IsPublic IsSerial Name                                     BaseType                                                                                                                           
-------- -------- ----                                     --------                                                                                                                           
True     True     Object[]                                 System.Array

但是如果我运行$ returnValue到Get-Member,我得到的是这个

$returnValue | Get-Member


TypeName: System.Boolean

将上面的代码更改为

即可轻松解决问题
function New-SampleFunction
{
    [void]('2')

     return $true
}

$myReturnValuen = New-SampleFunction

代码中的问题已解决,但我现在很好奇为什么这样做,我当然会缺少两个void和[void]::( blahblah)之间的区别,并且找不到任何明显的答案为此。

Probaly实在是太愚蠢了,我忽略了(度过了非常艰难的一周……),但如果有人能启发我,我将不胜感激。

谢谢!

1 个答案:

答案 0 :(得分:6)

最简单的形式将返回值抑制为使用$null = ...

$null = 2

其他情况下,在大多数情况下,不太理想的选项包括2 >$null2 | Out-Null[void] (2) [1]


关于您尝试过的事情

  

[void]::('2')

尝试访问名为:: 的类型为[void]静态成员2),这是该表达式的名称('2')的计算结果-显然不是您的意图。

由于[void]类型没有这样的静态成员(属性或方法),因此有效地返回了$null [2] -和$null 确实将输出输出到管道,因此您的函数具有 2 个输出,$null$true

如果将其捕获到变量中,则会得到一个由2个元素组成的[object[]]数组-$null, $true-可以解释症状。


[1]有趣的是,尝试使用[void] (...)作为表达式的一部分,导致在 Windows PowerShell 中出现错误。 em>在 Windows PowerShell (例如([void] 1), 2)中生成错误,而在PowerShell Core 中,现在更合理地将其视为$null(用$null -eq (([void] 1), 2)[0]验证)。

[2] 请注意,您可以通过调用Set-StrictMode -Version 2或更高版本来防止这种无意的方法/属性引用。 然后,您将收到以下语句终止错误:

The property '2' cannot be found on this object. Verify that the property exists.