转载自公众号:icqedu
今天是Batch入门教程的最后一章内容:调用与传参。相信通过前面的学习,大家已经掌握了Windows Batch有关的基础知识和编程方法,以及利用Windows Batch建立初级的编程思维方式。今后我们还会学习到更多的脚本语言,从而更加顺利投入到以后的开发和探究中。
** 前期回顾 **
调用与传参
虽然按照原理来讲,把所有的功能都放入一个Batch文件中是可行的,但是却会出现冗杂的问题。因此,我们可以创建多个Batch文件,并互相调用。在Batch中,我们使用call来对Batch文件进行调用并传参。start也可以传参,但是并不具备调用的性质,而仅仅是新运行指定的对象。
call
call指令的用法与一般的指令用法相同,都只需要指定对象即可:
后面的参数可以无限叠加。
我们先举一个比较简单的调用例子:
我们得到的结果是:
这很明显代表着我们已经将b.cmd打开了。不过,这不叫作「打开」,而叫作调用(Transfer)。
我们可以看到在上面我们给出的用法里,对象后面还有一个参数,而在上面的例子里却没有参数。这是正确的,只是功能会少一点而已。一般地,我们使用 call 就是为了带上参数。接下来我们来了解怎样使用这些参数。
首先我们要明白什么叫作参数(Parameter)。参数是指一个功能的实现所需要的条件和因素,它们一般都以数据的形式呈现。通俗来讲,就是实现这个功能所需要的数据。例如,我们要实现一个做加法的功能,我们都知道:
加数 + 加数 = 和
那么在这个运算中,两个加数就是参数,和是结果(result)。在编程中,这个结果叫作返回值(return value),这个流程所象征的基本意义所代指的概念叫作函数(Function)。
那么,我们既然要给别的.bat文件传参,那么它必定会实现某一个功能,实现功能就需要参数。那么,我们如何输入这些参数和获取这些参数呢?
首先我们要分清楚调用方(Caller)和被调用方(Callee)。我们先假定两个文件:a.cmd和b.cmd,它们的代码分别如下:
您能分清楚这里谁是调用方,谁是被调用方吗?调用方是a.cmd,被调用方是b.cmd,那么a.cmd就要给b.cmd传参。a.cmd里用到了一行call指令:
对应上面我们所表述的用法,b.cmd是对象,Hello则是一个参数。那么这个参数就相当于是告诉b.cmd 了,接下来我们要在b.cmd里使用它。于是我们就有了这行输出指令:
您能猜出%1的含义吗?
它是一个变量,但不是一个标准的变量。它代表着第一个参数。在上述指令中,从Hello开始即为参数,若我们执行:
我们得到:
在a.cmd中,我们传参(pass)给了b.cmd。这些参数分别为:
Hello,This,is,a,sentence,.。这分别是独立的6个参数,按照从左往右的顺序排序。
因此在被调用方b.cmd里,%1就代表Hello,%2就代表This,%3就代表is,以此类推。在上面的例子中,b.cmd内,%5%6写在了一起,因为%6的值是一个 .,与%5连用,结果则是sentence.。如果依然隔开,那么就是sentence .,显示并不自然。
现在我们知道了如何传参,以及如何调用参数。那么,我们处理的结果该如何返回呢?
exit /b
在Batch中 ,exit /b后必须接上数字,我们称为exitCode即退出码。它的作用是,当被调用时,作为被调用方,将会对调用方返回这个exitCode。只要exit 指令加上了参数/b,无论有没有接exitCode,它所退出的都是程序而不是进程。
这句话怎么理解呢?在第一章里我们已经给出了图示。如果退出的是程序,如果当前程序是被调用方,那么它会直接返回到调用方继续执行指令(如果当前程序没有被调用,那么exit /b等价于exit),但是如果退出的是进程,那么什么都不会做了,会将整个进程退掉。
我们来看个例子:
上述指令中我们用到了%ERRORLEVEL%,因为exit /b [errorCode],作为调用方时返回的exitCode会直接充当调用方的%ERRORLEVEL%。
上述例子我们实际上贯彻了函数的基本思想,但是在此不作具体供述。我们先看看结果:
输出的是2,正好是1+1的和。为什么呢?请看流程图:
也就是说我们传递给add.cmd的两个参数1, 1经过add.cmd内的一行指令set /a a=%1+%2的操作,将它们两个加起来的值赋给了a,然后再用a当作exitCode 使用exit /b %a% 将a的值传回a.cmd的%ERRORLEVEL%里,最后a.cmd输出它的值。这就是1+1的结果。
如果您仍然无法理解,可以在评论区提问。
需要注意的是exit /b的[exitCode] 仅能为Batch可以识别的数字,因此这种传参方式仅能够传回数字类型的参数。
call [bin] [param...]
这种用法与先前的用法并没有什么出入,仍然是后面跟上一个对象,以及要传给它的参数。这一点在于它所调用的对象并不是Batch文件,而是Windows的系统文件。利用这个功能,我们几乎可以完成任何操作。
例如,我们可以让电脑休眠:
其中,对于不同的对象,我们能够传入的参数是不一样的。如果要调用rundll32,我们就必须了解它的参数,在本教程中不加以供述。对于上面一行指令powercfg,它是用来改变休眠/睡眠状态的。如果powercfg -hibernate 设置为off,那么下面那行call 的结果就是睡眠,如果是on则是休眠。二者有一定的区别,各位可以通过搜索查看。