随笔 - 87, 文章 - 0, 评论 - 4, 阅读 - 24万

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

${FUNCNAME[@]}和$LINENO使用

Posted on   张鑫的园子  阅读(2496)  评论(0编辑  收藏  举报

$LINENO
代表shell脚本的当前行号

复制代码
[root@mysql-B ~]# cat test1.sh 
#!/bin/bash
trap 'echo “before execute line:$LINENO, a=$a,b=$b,c=$c”' DEBUG
a=1
if [ "$a" -eq 1 ]
then
   b=2
else
   b=1
fi
c=3
echo "end"

[root@mysql-B ~]# ./test1.sh 
“before execute line:3, a=,b=,c=”
“before execute line:4, a=1,b=,c=”
“before execute line:6, a=1,b=,c=”
“before execute line:10, a=1,b=2,c=”
“before execute line:11, a=1,b=2,c=3”
end
复制代码

 

$FUNCNAME
表示函数的名字,它是一个数组变量,其中包含了整个调用链上所有的函数的名字,故变量${FUNCNAME[0]}代表shell脚本当前正在执行的函数的名字,而变量${FUNCNAME[1]}则代表调用函数${FUNCNAME[0]}的函数的名字,依此类推。

 

复制代码
[root@mysql-B ~]# cat test1.sh 
#!/bin/bash

test1() {
  echo "aaa"
  local a=${FUNCNAME[@]}
  echo $a
}


test2() {
  test1
}
test2

[root@mysql-B ~]# ./test1.sh 
aaa
test1 test2 main  #输出结果为一个数组,第一个是被调用的函数名称,第二个是调用的函数名称,
            想只输出被调用的函数名称时,把@替换成0,想输入调用函数的名称时,@替换成1
复制代码

 

编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
历史上的今天:
2016-07-19 无法用sysadmin权限的登录名登陆,sa密码忘了,管理员被锁在外面
点击右上角即可分享
微信分享提示