C语言中我们经常使用DEBUG宏来控制是否输出调试信息,在shell脚本中,同样可以使用相同机制
if [[ "$DEBUG" == true ]];then
echo 'DEBUGGING'
fi
这样的代码块称之为 "调试钩子" 或 "调试块",在调试钩子内部可以输出调试信息,使用调试钩子的好处是可以通过DEBUG变量进行控制,在脚本的开发调试阶段,可以执行export DEBUG=true打开调试钩子,输出调试信息,脚本交付使用时,无需费事把脚本中的调试语句一一删除.
通过定义一个DEBUG函数,植入调试钩子
#!/bin/env sh
function DEBUG(){
if [ "$DEBUG" == true ];then
$@
fi
}
a=1
DEBUG echo "a=$a" # 通过DEBUG变量,控制信息输出
if [ "$a" -eq "1" ]
then
b=2
else
b=1
fi
DEBUG echo "b=$b"
c=3
DEBUG echo "c=$c"
export DEBUG=true
unset DEBUG