- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
为什么 PowerShell 在下面的第二个示例中显示出令人惊讶的行为?
首先,举一个理智行为的例子:
PS C:\> & cmd /c "echo Hello from standard error 1>&2"; echo "`$LastExitCode=$LastExitCode and `$?=$?"
Hello from standard error
$LastExitCode=0 and $?=True
没有惊喜。我向标准错误打印一条消息(使用 cmd
的 echo
)。我检查变量 $?
和 $LastExitCode
。正如预期的那样,它们分别等于 True 和 0。
但是,如果我要求 PowerShell 通过第一个命令将标准错误重定向到标准输出,我会得到一个 NativeCommandError:
PS C:\> & cmd /c "echo Hello from standard error 1>&2" 2>&1; echo "`$LastExitCode=$LastExitCode and `$?=$?"
cmd.exe : Hello from standard error
At line:1 char:4
+ cmd <<<< /c "echo Hello from standard error 1>&2" 2>&1; echo "`$LastExitCode=$LastExitCode and `$?=$?"
+ CategoryInfo : NotSpecified: (Hello from standard error :String) [], RemoteException
+ FullyQualifiedErrorId : NativeCommandError
$LastExitCode=0 and $?=False
我的第一个问题,为什么会出现 NativeCommandError?
其次,为什么cmd
运行成功,$LastExitCode
为0时,$?
为False? PowerShell 的文档 about automatic variables没有明确定义 $?
。当且仅当 $LastExitCode
为 0 时,我一直认为它为 True,但我的示例与此相矛盾。
以下是我在现实世界(简化版)中遇到这种行为的方式。这真的是 FUBAR。我正在从另一个调用一个 PowerShell 脚本。内部脚本:
cmd /c "echo Hello from standard error 1>&2"
if (! $?)
{
echo "Job failed. Sending email.."
exit 1
}
# Do something else
简单地以 .\job.ps1
运行它,它工作正常,并且没有发送电子邮件。但是,我是从另一个 PowerShell 脚本调用它的,记录到文件 .\job.ps1 2>&1 > log.txt
。在这种情况下,将发送一封电子邮件!您在脚本外部使用错误流执行的操作会影响脚本的内部行为。 观察现象会改变结果。这感觉更像是量子物理学而不是脚本!
[有趣的是:.\job.ps1 2>&1
可能会或不会爆炸,这取决于你在哪里运行它]
最佳答案
(我使用的是 PowerShell v2。)
“$?
”变量记录在 about_Automatic_Variables
中:
$? Contains the execution status of the last operation
这是指最近的 PowerShell 操作,而不是上次外部命令,后者是您在 $LastExitCode
中获得的内容。
在您的示例中,$LastExitCode
为 0,因为最后一个外部命令是 cmd
,它成功回显了一些文本。但是 2>&1
导致发送到 stderr
的消息被转换为输出流中的错误记录,这告诉 PowerShell 在上次操作,导致 $?
为 False
。
为了进一步说明这一点,请考虑以下内容:
> java -jar foo; $?; $LastExitCodeUnable to access jarfile fooFalse1
$LastExitCode
是 1,因为那是 java.exe 的退出代码。 $?
为 False,因为 shell 做的最后一件事失败了。
但如果我所做的只是将它们调换:
> java -jar foo; $LastExitCode; $?Unable to access jarfile foo1True
... 然后 $?
为 True,因为 shell 所做的最后一件事是向主机打印 $LastExitCode
,这是成功的。
最后:
> &{ java -jar foo }; $?; $LastExitCodeUnable to access jarfile fooTrue1
...这似乎有点违反直觉,但 $?
现在是 True,因为脚本 block 的执行成功,即使在其中运行的命令不是。
返回到 2>&1
重定向....导致错误记录进入输出流,这就是关于 NativeCommandError
。 shell 正在转储整个错误记录。
当您只想通过管道将
stderr
和 stdout
放在一起以便将它们合并到一个日志文件中时,这可能会特别烦人或者其他的东西。谁想让 PowerShell 插进他们的日志文件???如果我执行 ant build 2>&1 >build.log
,那么任何转到 stderr
的错误都会附加 PowerShell 的 nosey $0.02,而不是在我的日志文件中获取干净的错误消息。
但是,输出流不是文本 流!重定向只是对象 管道的另一种语法。错误记录是对象,因此您所要做的就是在重定向之前将该流上的对象转换为字符串:
来自:
> cmd /c "echo Hello from standard error 1>&2" 2>&1cmd.exe : Hello from standard errorAt line:1 char:4+ cmd &2" 2>&1 + CategoryInfo : NotSpecified: (Hello from standard error :String) [], RemoteException + FullyQualifiedErrorId : NativeCommandError
收件人:
> cmd /c "echo Hello from standard error 1>&2" 2>&1 | %{ "$_" }Hello from standard error
...并重定向到一个文件:
> cmd /c "echo Hello from standard error 1>&2" 2>&1 | %{ "$_" } | tee out.txtHello from standard error
...或者只是:
> cmd /c "echo Hello from standard error 1>&2" 2>&1 | %{ "$_" } >out.txt
关于windows - $LastExitCode=0,但 $?=False 在 PowerShell 中。将 stderr 重定向到 stdout 会给出 NativeCommandError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10666101/
我想看看我是否可以获得有关错误代码的帮助。我的最终脚本是为邮箱设置 SMTP 地址,但我只是使用下面的代码作为示例。 Set-Mailbox jsmith -AntispamBypassEnabled
您好,我注意到以下代码片段出现了一些奇怪的行为 function test { $LASTEXITCODE = $null ping asdfs Write-Host "Las
我快疯了,有人能解释一下为什么 $lastexitcode 的值是未定义的吗? 看看我的简单尝试:如果我启动命令 dir,我会得到正确的输出,所以 $LASTEXITCODE 必须为 0。 不幸的是,
我想从PowerShell调用VisualBuild构建并获取它的最后一个退出代码。 我调用Build使用。 Start-Process -FilePath $VisualBuild -Argumen
我已经编写了一个Powershell脚本来调用sqlcmd.exe以对远程sql服务器执行sql脚本。 Powershell脚本检查$ LASTEXITCODE。如果$ LASTEXITCODE不为零
我有一组测试 DLL,我从一个 powershell 脚本运行,该脚本通过 Start-Process 调用 OpenCover.Console.exe命令。 我有 -returntargetcode
我的 powershell 配置文件有一个自定义的 powershell 提示,不幸的是会导致 $lastexitcode 值丢失。例如,给定一个 powershell 脚本“fail.ps1”,内容
我在Powershell脚本块中定义的机器上执行了一系列“任务”,如下所示(它们实际上是作为更复杂的包含脚本块的哈希数组传递的)。 $Tasks = @( { hostname.exe },
在 PowerShell 中,$? 和 $LastExitCode 有什么区别? 我读了about automatic variables ,它说: $? Contains the execution
我在此处的代码项目上使用 powershell 异步执行代码在 C# 中执行了一个 scipt: http://www.codeproject.com/KB/threads/AsyncPowerShe
我有一个包含外部命令 ( csrun.exe ) 的自定义模块,并解析输出,以便我可以在 PowerShell 中使用它。 除非外部命令写入 stderror 并且清除我的 cmdlet 中的错误似乎
我绝不是 PowerShell 专家;我在谷歌上搜索了一段时间,但没有找到答案。 我的脚本的基本思想是使用命令行参数运行名为 appcert.exe 的 Microsoft 工具。 appcert.e
我正在使用 robocopy在 Gitlab 管道中的构建步骤期间复制文件。管道任务在 powershell 中执行。 robocopy的退出状态导致我的构建步骤失败。我注意到所有低于 8 的状态码都
我注意到,当 MSBuild 失败时,$LastExitCode 变量的值始终为 0。我使用的是 Windows 7,使用 MSBuild v4.0 和 PowerShell 2.0。这是我的 MSB
为什么 PowerShell 在下面的第二个示例中显示出令人惊讶的行为? 首先,举一个理智行为的例子: PS C:\> & cmd /c "echo Hello from standard error
我是一名优秀的程序员,十分优秀!