一般shell/ target=_blank class=infotextkey>shell脚本的调试基本都是echo,对于单行文本或较短的代码,此方法不错。
但对于内容较多的代码时,显示得无能为力。
其实shell内置的一些变量,可以帮助解决问题:
$LINENO $FUNCNAME $BASH_LINENO 这几个变量记录了脚本当前的执行位置,以及正在执行的函数。具体可以可以man 文档页。
实例代码:a.sh
b.sh:
执行结果:
我在b.sh 里写了cdf 函数调用 abc 函数 ,看到输出的差别了吧,可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用等。