命令放在具体的语境中更能说明其用途:
例1: "$#", "echo", "exit", " -lt " ,
if [ $# -lt 1 ];then
echo "Error! Should enter the root directory of xcode project after the ipa-build command."
exit 2
fi
//综述:当当前脚本接受的参数个数小于1个(没有参数输入)的时候,输出 "Error!..." ,后退出当前脚本,并返回数字 "2"
// "$#" :脚本当前输入参数的个数 ,
// "$0" :当前脚本的名字, "$1":脚本输入的第一个参数,
// "$$" :当前脚本的进程号
// " -lt " 是小于的意思
// "echo" :相当于 " print" 或者 OC 中的" NSLog "
// "exit" :退出当前脚本
// "exit 2" :退出当前脚本并返回 数字 " 2 "
"exit 2"
in shell, there is a special variable $?, which catch the status of last command:
// 在shell中, 有一个特殊的变量 "$? ", 它的作用是:获取上一个命令的状态
after "ls", "echo $?" will return 0, meaning a successful command;
after "xxxxxx", "echo $?" will be a non-zero, since xxxxxx is not
an command.
// 如果" ls "或者"echo $?" 返回 0 , 表示上一条命令的状态是成功的. 字符串后面使用 "echo $?" ,返回的是非零值, 因为字符串不是命令
Now, in the above script, exit 0 and exit 1 is up to your choice.
but you still can use $? to catch that value, since Shell treat
"if ....;then .....fi" as a command
// 在上面的shell 中 ,你可以自己选择是 exit 0 或者exit 1 , 但是你仍然可以使用$?, 尽管 Shell 把"if ....;then .....fi" 当做一个命令.
当你 exit 0 的时候
在调用环境 echo $? 就返回0 ,也就是说调用环境就认为 你的这个程序执行正确
当 exit 1 的时候,一般是出错定义这个1,也可以是其他数字,很多系统程序这个错误编号是有约定的含义的。
但不为0 就表示程序运行出错。 调用环境就可以根据这个返回值判断 你这个程序运行是否ok。
如果你用 脚本 a 调用 脚本b ,要在a中判断b是否正常返回,就是根据 exit 0 or 1 来识别。
执行完b后, 判断 $? 就是返回值
getopts
unix有一个优点就是标准UNIX命令在执行时都具有相同的命令行格式:
command -options parameters
getopts option_string variable
getopts的作用:在Shell 中获取处理命令行,(主要就是分析,检测 command -options parameters ), eg :( command -a parameters )
//就是分析输入命令行的语句,(主要是带参数的命令语句)
option_string : 这个参数就是设置命令行参数的格式的,也是就命令行的参数的名字(检测命令行参数的,实际上也是设置参数的,因为脚本中需要根据参数的名字来把值传递给相应的变量)
getopts 返回错误的模式有两种. 1.错误静默模式
2.错误非静默模式
.如果option_string的第一个字符是 冒号" :",getopts 就采用错误静默模式
,在这种模式下错误是不会被打印的(显示到当前的操作台上,也就是标准输出上).如果一个无效的选项(没有定义的)被检测到,getopts会把这个选项名(单个字符)存入到 变量OPTARG(系统保留变量名)中.如果一个需要参数的选项被检测到没有参数,getopts 会 把 NAME 设置为" : " ,OPTARG 设置为这个选项名. 如果getopts没有在错误静默模式
的模式下,一个无效的选项名(没有定义的)被检测到,getopts 会把NAME设置为" ? ", OPTARG不设置. 如果一个需要参数的选项被检测到没有输入参数, NAME 会这只成" ? ",OPTRAG 不设置,一个相应的诊断报告被打印到标准输出上.
如果shell 的参数 OPTERR 的值是 0 , getopts 就不会输出错误信息尽管option_string的第一个字符是不是 " : ", OPTERR 系统默认是 1 .
getopts一般格式为:
getopts option_string variable
其中option_string中包含一个有效的单字符选项。若getopts命令在命令行中发现了连字符,那么它将用连字符后面的字符同option_string相比较。若有匹配,则把变量variable的值设为该选项。若无匹配,则variable设为?。当getopts发现连字符后面没有字符,会返回一个非零的状态值。Shell程序中可以利用getopts的返回值建立一个循环。
有时侯选项中还带一个值,getopts命令同样也支持这一功能。这时需要在option_string中选项字母后加一个冒号。当getopts命令发现冒号后,会从命令行该选项后读取该值。若该值存在,那么将被存在一个特殊的变量OPTARG中。如果该值不存在,getopts命令将在OPTARG中存放一个问号,并且在标准错误输出上显示一条消息。
optstring option字符串,会逐个匹配
varname 每次匹配成功的选项
arg 参数列表,没写时它会取命令行参数列表
$OPTIND 特殊变量,option index,会逐个递增, 初始值为1
$OPTARG 特殊变量,option argument,不同情况下有不同的值
细则1:当optstring以”:”开头时,getopts会区分invalid option错误和miss option argument错误。
invalid option时,varname会被设成?,$OPTARG是出问题的option;
miss option argument时,varname会被设成:,$OPTARG是出问题的option。
如果optstring不以”:“开头,invalid option错误和miss option argument错误都会使varname被设成?,$OPTARG是出问题的option。
细则2:当optstring中的字母跟”:“时,表明该option可接参数,参数(argument)放在$OPTARG中;
如果缺参数,且optstring是以”:“开头,则varname的值会是:,$OPTARG是该option,否则varname的值是?,$OPTARG是该option。(参照细则1)
示例:
param_pattern=":p:nc:"
while getopts $param_pattern optname
do
case "$optname" in
"n")
should_clean=y
;;
"p")
#这里写是-p 时 的处理逻辑, # 是注释符 类比 " // "
;; # 这里两个" ;; " 相当于 break
"?") # 当输入不识别的选项时会进入到这里面
echo "Error! Unknown option $OPTARG"
exit 2
;;
esac
done