首页 > 技术文章 > shell:调试钩子

dissipate 2020-09-22 18:27 原文

 

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

 

 

 

推荐阅读