一.shell简介
shell的作用是解释执行用户的命令,用户输入一条命令,shell就执行一条,这种方式称为交互式,shell还有一种执行命令的方式是批处理,用户事先写一个shell脚本,让shell一次把所有命令一次执行完。
二.shell执行脚本
shell脚本用#表示注释,但在第一行时例外,这个时候表示该脚本使用后面指定的解释器/bin/sh解释执行。shell脚本运行原理:
交互Shell(bash)fork/exec一个子Shell(sh)用于执行脚本,父进程bash等待子进程sh终 止。
2. sh读取脚本中的cd ..命令,调用相应的函数执行内建命令,改变当前工作目录为上一级目 录。
3. sh读取脚本中的ls命令,fork/exec这个程序,列出当前工作目录下的文件,sh等待ls终止。
4. ls终止后,sh继续执行,读到脚本文件末尾,sh终止。
5. sh终止后,bash继续执行,打印提示符等待用户输。
如果将命令行下输入的命令用()括号括起来,那么也会fork出一个子Shell执行小括号中的命令,
cd、source或者.命令是Shell的内建命令,这种方式也不会创建子Shell,而是直接在交互式Shell下逐行执脚本中的命令。
三。shell变量
Shell变量由全大写字母加下划线组成,有两种类型的Shell变量:
环境变量
环境变量可以从父进程传给子进程,因此Shell进程的环境变量 可以从当前Shell进程传给fork
出来的子进程。用printenv命令可以显示当前Shell进程的环境 变量。
本地变量
只存在于当前Shell进程,用set命令可以显示当前Shell进程中定义的所有变量(包括本地变 量
和环境变量)和函数。
环境变量是任何进程都有的概念,而本地变量是Shell特有的概念。在Shell中,环境变量和本
地变 量的定义和用法相似。在Shell中定义或赋值一个变量:
VARNAME=value
注意等号两边都不能有空格,否则会被Shell解释成命令和命令行参数。一个变量定义后仅
存在于当前Shell进程,它是本地变量,用export命令可以把本地变量导出为环境变量,定义和导出环境变量通常可以 一步完成:
export VARNAME=value
也可以分两步完成:
VARNAME=value
export VARNAME
用unset命令可以删除已定义的环境变量或本地变量.
四。变量引用
如果一个变量叫做VARNAME,用${VARNAME}可以表示它的值,在不引起歧义的情况下也
可以 用$VARNAME表示它的值。通过以下例子比较这两种表示法的不同:
echo $SHELL
echo $SHELLabc
对比:
echo ${SHELL}
echo ${SHELL}abc
注意,在定义变量时不用$,取变量值时要用$。和C语言不同的是,Shell变量不需要明确定义
类 型,事实上Shell变量的值都是字符串,比如我们定义VAR=45,其实VAR的值是字符串45而非
整 数。Shell变量不需要先定义后使用,如果对一个没有定义的变量取值,则值为空字符串。
五。文件名代换 (Globbing )::* ? []
这些用于匹配的字符称为通配符(Wildcard),具体如下:
通配符 * : 匹配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命令的参数
实际 上是这两个文件名,而不是一个匹配字符串。
六.单引号
和C语言不一样,Shell脚本中的单引号和双引号一样都是字符串的界定符(双引号下一节介绍),
而不是字符的界定符。单引号用于保持引号内所有字符的字面值,即使引号内的\和回车也不
例外, 但是字符串中不能出现单引号。如果引号没有配对就输入回车,Shell会给出续行提示符,
要求用户 把引号配上对。例如:
七.双引号
双引号用于保持引号内所有字符的字面值(回车也不例外),但以下情况除外:
$加变量名可以取变量的值
反引号仍表示命令替换
\$表示$的字面值
\`表示`的字面值
\"表示"的字面值
\\表示\的字面值 除以上情况之外,在其它字符前面的\无特殊含义,只表示字面值: