set path=d:/;%path%如果非要拿 java 作比喻,可以等效于 s = "d:/;" + s; 其中 s 是字符串类型变量。
这是 dos 命令啊,你有木有用过 bash shell 呢,其实格式差不多啦,他们都算作是脚本语言啦。这个也和 java 差不多嘛。path 可以看做 dos 这个程序的字符串类型变量,给变量赋值用语句 set 变量名=字符串 ,使用变量的值是 %变量名% 这种格式(使用变量的值在 javascript 中还是 $变量名 这种格式呢),set path=d:/;%path% ,这条语句里面,dos 先把 %path% 的值取出来,就是 path 以前的值嘛假设是字符串"xxx",然后把 d:/; 拼接在刚刚得到的字符串前面就得到"d:/;xxx",再把“d:/;xxx”这个字符串赋值给 path 变量。如果这样写 set path=%path%;d:/; 那么 path 最后的值就是“xxx;d:/;”(我在d前面加个 ; 是怕 path 前一个值结尾不是 ; 号,那样的话,我设置的路径和前面一个路径就连一起了,到时候 dos 解析 path 这个路径的时候最后一个用不了。)
关于你说的 set 的规则,我建议你可以在命令行里面输入 help set 查看 set 这个命令的帮助,它会详细告诉你 set 这个名了有哪些用法,不过我一般不看啦,记住主要的就行嘛,那么多命令记不完啦,特别是外置命令,外置命令用 命令名 -help 格式来查看,比如 java -help ,一个应用程序就可以是一个命令,不同程序的命令的参数格式还不同,这些参数格式都是写程序的人自己定义的,所以记不完嘛,用的时候 help 一下啦。
path 变量是 dos 要使用的特殊的变量,dos 要执行某个命令的时候,先是查找内部命令,也就是 dos 自带的命令(比如刚刚的 set 就是 dos 自带的命令,除了这个 dos 还有分支语句、循环语句呢),没有的话再按照 path 里面的路径从左到右查找,最先被找到这个命令对应的可执行文件,也就是 xxx.exe 就执行这个 xxx.exe 啦,说得专业一点就是给这个应用程序创建一个子进程来执行这个程序。
下面是我用 help set 得到的结果:
C:\Users\vivianZhao>help set
显示、设置或删除 cmd.exe 环境变量。
SET [variable=[string]]
variable 指定环境变量名。
string 指定要指派给变量的一系列字符串。
要显示当前环境变量,键入不带参数的 SET。
如果命令扩展被启用,SET 会如下改变:
可仅用一个变量激活 SET 命令,等号或值不显示所有前缀匹配
SET 命令已使用的名称的所有变量的值。例如:
SET P
会显示所有以字母 P 打头的变量
如果在当前环境中找不到该变量名称,SET 命令将把 ERRORLEVEL
设置成 1。
SET 命令不允许变量名含有等号。
在 SET 命令中添加了两个新命令行开关:
SET /A expression
SET /P variable=[promptString]
/A 命令行开关指定等号右边的字符串为被评估的数字表达式。该表达式
评估器很简单并以递减的优先权顺序支持下列操作:
() - 分组
! ~ - - 一元运算符
* / % - 算数运算符
+ - - 算数运算符
<< >> - 逻辑移位
- 按位“与”
^ - 按位“异”
| - 按位“或”
= *= /= %= += -= - 赋值
&= ^= |= <<= >>=
, - 表达式分隔符
如果您使用任何逻辑或取余操作符, 您需要将表达式字符串用
引号扩起来。在表达式中的任何非数字字符串键作为环境变量
名称,这些环境变量名称的值已在使用前转换成数字。如果指定
了一个环境变量名称,但未在当前环境中定义,那么值将被定为
零。这使您可以使用环境变量值做计算而不用键入那些 % 符号
来得到它们的值。如果 SET /A 在命令脚本外的命令行执行的,
那么它显示该表达式的最后值。该分配的操作符在分配的操作符
左边需要一个环境变量名称。除十六进制有 0x 前缀,八进制
有 0 前缀的,数字值为十进位数字。因此,0x12 与 18 和 022
相同。请注意八进制公式可能很容易搞混: 08 和 09 是无效的数字,
因为 8 和 9 不是有效的八进制位数。(& )
/P 命令行开关允许将变量数值设成用户输入的一行输入。读取输入
行之前,显示指定的 promptString。promptString 可以是空的。
环境变量替换已如下增强:
%PATH:str1=str2%
会扩展 PATH 环境变量,用 "str2" 代替扩展结果中的每个 "str1"。
要有效地从扩展结果中删除所有的 "str1","str2" 可以是空的。
"str1" 可以以星号打头;在这种情况下,"str1" 会从扩展结果的
开始到 str1 剩余部分第一次出现的地方,都一直保持相配。
也可以为扩展名指定子字符串。
%PATH:~10,5%
会扩展 PATH 环境变量,然后只使用在扩展结果中从第 11 个(偏
移量 10)字符开始的五个字符。如果没有指定长度,则采用默认
值,即变量数值的余数。如果两个数字(偏移量和长度)都是负数,
使用的数字则是环境变量数值长度加上指定的偏移量或长度。
%PATH:~-10%
会提取 PATH 变量的最后十个字符。
%PATH:~0,-2%
会提取 PATH 变量的所有字符,除了最后两个。
终于添加了延迟环境变量扩充的支持。该支持总是按默认值被
停用,但也可以通过 CMD.EXE 的 /V 命令行开关而被启用/停用。
请参阅 CMD /?
考虑到读取一行文本时所遇到的目前扩充的限制时,延迟环境
变量扩充是很有用的,而不是执行的时候。以下例子说明直接
变量扩充的问题:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "%VAR%" == "after" @echo If you see this, it worked
)
不会显示消息,因为在读到第一个 IF 语句时,BOTH IF 语句中
的 %VAR% 会被代替;原因是: 它包含 IF 的文体,IF 是一个
复合语句。所以,复合语句中的 IF 实际上是在比较 "before" 和
"after",这两者永远不会相等。同样,以下这个例子也不会达到
预期效果:
set LIST=
for %i in (*) do set LIST=%LIST% %i
echo %LIST%
原因是,它不会在目前的目录中建立一个文件列表,而只是将
LIST 变量设成找到的最后一个文件。这也是因为 %LIST% 在
FOR 语句被读取时,只被扩充了一次;而且,那时的 LIST 变量
是空的。因此,我们真正执行的 FOR 循环是:
for %i in (*) do set LIST= %i
这个循环继续将 LIST 设成找到的最后一个文件。
延迟环境变量扩充允许您使用一个不同的字符(惊叹号)在执行
时间扩充环境变量。如果延迟的变量扩充被启用,可以将上面
例子写成以下所示,以达到预期效果:
set VAR=before
if "%VAR%" == "before" (
set VAR=after
if "!VAR!" == "after" @echo If you see this, it worked