shell脚本实现分日志级别输出(2)

输出如下:

这里写图片描述


在写这个函数的遇到一个问题就是不能用内建变量$LINENO来取得调用的行号,只能取得log函数中定义$LINENO那一行,搜了许久找到的解决办法是利用caller命令,关于caller命令的用法,如下:
5.caller的用法
caller命令放到函数中, 将会在stdout上打印出函数的调用者信息.,caller命令也可以在一个被source的脚本中返回调用者信息. 当然这个调用者就是source这个脚本的脚本. 就像函数一样, 这是一个”子例程调用”.你会发现这个命令在调试的时候特别有用.

#!/bin/bash function1 () { # 在 function1 () 内部. caller 0 # 显示调用者信息. } function1 # 脚本的第9行. # 9 main test.sh # ^ 函数调用者所在的行号. # ^^^^ 从脚本的"main"部分开始调用的. # ^^^^^^^ 调用脚本的名字. caller 0 # 没效果, 因为这个命令不在函数中.

本文永久更新链接地址

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/126cec97db8af854113ad296bd4aef17.html