教程集 www.jiaochengji.com
教程集 >  脚本编程  >  shell  >  正文 shell脚本用内置变量调试

shell脚本用内置变量调试

发布时间:2014-12-14   编辑:jiaochengji.com
本文介绍了用内置变量调试shell脚本的方法,有学习shell编程的朋友做个参考。

一般shell脚本的调试基本都是echo,对于单行文本或较短的代码,此方法不错。
但对于内容较多的代码时,显示得无能为力。

其实shell内置的一些变量,可以帮助解决问题:
$LINENO  $FUNCNAME $BASH_LINENO 这几个变量记录了脚本当前的执行位置,以及正在执行的函数。具体可以可以man 文档页。

实例代码:a.sh
 

#!/bin/bash
abc() {
echo "wo shi abc()"
echo  "func: $FUNCNAME  ln: $LINENO ln2:${BASH_LINENO[1]} brother: ${FUNCNAME[1]}"
}

b.sh:
 

#!/bin/bash
../a.sh
abc
cdf() {
abc
}

执行结果:
 

复制代码 代码示例:
[root@node2 ~]# ./b.sh
[code]wo shi abc()
func: abc  ln: 5 ln2:0 brother: main
wo shi abc()func: abc  ln: 5 ln2:9 brother: cdf
 

我在b.sh 里写了cdf 函数调用 abc 函数 ,看到输出的差别了吧,可以利用这些参数打印出代码出错行的位置,以及代码出错时,是由哪个函数调用等。

您可能感兴趣的文章:
shell脚本用内置变量调试
为shell编程新手准备的教程
sed、awk调用shell变量的方法
shell编程技巧小结(三)
bash shell脚本执行的几种方法
shell脚本学习指南之shell变量
shell脚本编程基础知识(8)-脚本调试
bash shell获取当前正执行脚本的绝对路径
shell位置变量实现目录文件备份脚本
shell 脚本调试方法分析

关键词: shell变量  脚本调试   
[关闭]
~ ~