当前位置:文档之家› PowerShell的Exit与Return

PowerShell的Exit与Return

PowerShell的Exit关键字与Return关键字,以及自动变量$?和$LastExitCode
——与Unix Shell的比较
最近因为工作关系,第一次接触PowerShell。

因为之前接触的都是Unix Shell,所以在刚开始用PowerShell的时候,把Unix的想法与概念带到PowerShell中,到最后才发现二者之间很多东西都是不一样的。

关于这次的工作内容,主要任务是把原来在Unix上写的Shell用PowerShell再实现一下。

需求与接口都要求与原来的一样(实际上谁也不想改这些东西)。

一、Exit关键字
语法:Exit [状态值]
这个不用想都知道是退出命令,中止当前的执行。

但是这里面却是一大堆的陷阱。

在Unix Shell中,只要Exit被执行,不管Shell之间用source命令有多少层读取关系,都会中止所以执行,并且设置退出状态值。

状态值在执行结束之后用$?来确认。

一切都很清楚。

但是在PowerShell中却变得比较复杂。

先看一下PowerShell2.0中关于Exit的说明,少得可怜。

另外,在《Window PowerShell应用手册》里关于Exit也没有特别的说明。

对PowerShell中Exit的命令,分成下面三种情况。

1、在脚本中直接执行。

2、在用source读取的脚本中执行。

3、在函数中执行。

分别用例子来说明。

1、在脚本中直接执行。

这种情况下和Unix Shell是一样的,都是中止脚本的执行。

不同的是在PowerShell中自动变量$?是一个布尔值,因为退出代码不是0而是50,所以执行结束是失败(False);自动变量$LastExitCode里保存的则是退出代码。

2、在用source读取的脚本中执行。

用testMain.ps1文件读取上一个例子中的脚本。

可以看到即使test1.ps1的执行了Exit命令并中止了执行,但是testMain.ps1却还是继续执行后面的命令。

这一点和Unix Shell完全不一样。

3、在函数中执行。

这种情况下和Unix Shell 也是一致的。

补充说明一下,即使这个函数是在另一个脚本中定义的,通过读取该文件后调用这个函数,结果也是一样的。

二、关于$?和$LastExitCode
在上面的几个例子里用到了这两个自动变量来查看脚本的执行结果。

先看一下PowerShell2.0帮助手册里的说明,内容也一样很简单。

$?都是用来确定前一个命令的执行状态,如果是脚本的话,由Exit 命令后面所带的参数和决定执行状态。

0是True ,0以外的数字都是False 。

所有的程序和命令都会在执行后设置$?的值。

$LastExitCode 的值是由Exit [状态值]命令来设置的。

需要注意的是,并不是所有的命令和程序都会去设置这一个自动变量;也就是说,你现在看到$LastExitCode 的值可能并不是前一个命令设置的,而是更早之前的某一个命令设置之后一直保持下来的值。

还有一点需要注意的是,当你刚打开一个PowerShell 的时候,$LastExitCode 这个自动变量是不存在的,只有在某一个设置$LastExitCode 的命令执行过以后才会出现。

刚开始时,我一直以为$?和$LastExitCode 保存的都是前一个命令的结果,直到后来做测试时才发现不是。

之后再找了一下资料,也没有发现相关的说明。

有兴趣的朋友可以自己测试一下。

三、Return 关键字
首先看一下在Return 命令在Unix Shell 中的作用。

Return 和Exit
一样都可以设置命令的执行
状态值,不同的是Exit会中止脚本的执行,而Return不会中止脚本的执行。

在PowerShell里虽然也有Return这一个命令,但是和Unix Shell的完全就是两个不同的概念。

在PowerShell里只有Exit可以设置$LastExitCode,但是Return不能做到。

先看一下PowerShell2.0帮助手册的说明:
所以这里的Return,不是像Unix Shell一样设置%?,也不像C或Java一样只返回Return关键字后面所跟的值,而是当前脚本或函数所有语句的输出。

如果Return前面只有一个输出的话,就是把那个输出返回;如果是有多个输出的话,返回值如下图所示是一个Object数组。

这是一个会让人崩溃的结果,真不知道PowerShell的设计者脑子是不是进水了,还是有我无法想像到的深意在里面。

总结,PowerShell和Unix Shell完全是两种不同的语言,有相似的地方,但是更多的是不同。

工作上碰到的问题,都只能说是自己对这两者的理解都还十分肤浅,不能够运用自如。

2016年1月16日
关于这篇文章
从接触PowerShell开始,有问题上网找资料时发现关于PowerShell的资料比较少,就想把自己的一些理解写出来分享一下。

第一次写这种文章,加上从事工作资历也比较短,不足之处还请大家多多包涵。

文中的观点与理解如有错误,请务必指正出来,不胜感激。

邮箱:xxbcf@
关于作者
80后,2013年才进入IT行业,工作经验与水平都处在入门水平。

相关主题