hell执行脚本
#!/bin/bash
Echo “这是一个shell脚本”;
shell脚本中用#表示注释,如果#位于第一⾏开头,并且是则例外,
它表⽰该脚本使⽤后⾯指定的解释器/bin/sh解释执⾏。
第一种执行方式:chmod +x script.sh
Shell会fork一个子进程并调⽤用exec执行./script.sh这个程序,exec系统调用应该把子进程的代码段替换成./script.sh程序的代码段,并从它的_start开始执行。然而script.sh是个⽂本⽂件,根本没有代码段和_start函数,怎么办呢?其实exec还有另外一种机制,如果要执行的是一个⽂本文件,并且第一行用Shebang 指定了解释器,则用解释器程序的代码段替换当前进程,并且从解释器的_start开始执行,⽽而这个文本文件被当作命令行参数传给解释器。因此,执行上述脚本相当于执⾏行程序 。
第二种执行方式:/bin/bash script.sh
Shell变量
环境变量:环境变量可以从⽗进程传给⼦进程,因此Shell进程的环境变量可以从当前Shell进程传给fork出来的子进程。用printenv命令可以显⽰示当前Shell进程的环境变量。任何进程都由的概念。
本地变量:只存在于当前Shell进程,⽤set命令可以显⽰当前Shell进程中定义的所有变量(包括本地变量和环境变量)和函数。也叫局部变量。
*VARNAME=value 注意在定义变量的时候等号俩边都不能有空格,否则会被Shell解释成命令和命令行参数,一个变量定义后仅存在于当前shell进程,它是本地变量,但是export命令可以把本地变量导出为环境变量,定义和导出环境变量可一步完成。如 export VARNME=value
用unset可以删除已定义的环境变量。
变量的引用:
变量的引用有俩种方式1.echo $SHELL echo $SHELL 2.echo ${SHELL} echo ${SHELL}abc
*注意在shell中变量不需要先定义后使用,如果对一个没有定义的变量取值,则值是空字符串,并且在定义时不用$在取变量值时要用$,shell不需要明确定义类型,shell变量的值都是字符串。
文件名带换
*:匹配0个或多个任意字符串
?:匹配一个字符串
[]:匹配方括号中任意一个字符的一次出现
例:$ls /dev/ttyS*
$ls ch0?.doc
$ls ch0[0-2].doc
$ls ch[012][0-9].doc
*注意,Globbing所匹配的⽂件名是由Shell展开的,也就是说在参数还没传给程序之前已经展开了, ⽐如上述ls ch0[012].doc命令,如果当前⽬录下有ch00.doc和ch02.doc,则传给ls命令的参数实际上是这两个⽂件名,⽽不是⼀个匹配字符串。
这些用于匹配的字符称为通用符
命令代换
由反引号括起来的也是⼀条命令,Shell先执⾏该命令,然后将输出结果⽴刻代换到当前命令⾏中。
$ DATE=`date`
$ echo $DATE
例如定义一个变量存放date命令的输出:
命令代换也可以⽤$()表⽰: DATE=$(date)
算术代换:$(())
⽤于算术计算,$(())中的Shell变量取值将转换成整数,例如:
$ VAR=45
$ echo $(($VAR+3))
$(())中只能⽤+-*/和()运算符,并且只能做整数运算。
转义字符
\在Shell中被⽤用作转义字符 如创建一个名为“$ $”的文件可以写成$touch \$\ \$\
还有一个字符虽然不具有特殊含义,但是要⽤它做⽂件名也很⿇烦,就是-号。如果要创建⼀个⽂件名以-号开头的⽂件,这样是不⾏的: 即使加上\转义也还是报错: 因为各种UNIX命令都把-号开头的命令⾏参数当作命令的选项,⽽不会当作⽂件名。如果⾮要处理 以-号开头的⽂件名,可以有两种办法: $touch ./-hello 或者$ touch -- -hello
单引号:
和C语⾔言不⼀样,Shell脚本中的单引号和双引号⼀样都是字符串的界定符(双引号下⼀节介绍),⽽不是字符的界定符。单引号⽤于保持引号内所有字符的字⾯值,即使引号内的\和回车也不例外, 但是字符串中不能出现单引号。
双引号:
双引号⽤于保持引号内所有字符的字⾯值(回车也不例外),但以下情况除外:
$加变量名可以取变量的值
反引号仍表⽰命令替换
\$表⽰$的字⾯值
\`表⽰`的字⾯值(反引号)
\"表⽰"的字⾯值
\\表⽰\的字⾯值 除以上情况之外,在其它字符前⾯的\⽆特殊含义,只表⽰字⾯面值