这些变量都是由bash
这个程序本身进行修改使用;
其他shell
不一定试用;
$_
todo
BASH
当前bash
的完整路径;
BASHOPTS
shopt -s
打开的选项, 用:
分隔;
如果环境变量中定义, 再启动子shell
会先读取并启动, 即继承;
$ echo ${BASHOPTS}
checkwinsize:cmdhist:complete_fullquote:expand_aliases:extglob:extquote:force_fignore:histappend:interactive_comments:login_shell:progcomp:promptvars:sourcepath
$ shopt -s extdebug
$ echo ${BASHOPTS}
checkwinsize:cmdhist:complete_fullquote:expand_aliases:extdebug:extglob:extquote:force_fignore:histappend:interactive_comments:login_shell:progcomp:promptvars:sourcepath
可以看到设置了新的shopt
, 变量也会变化;
BASHPID
当前上下文的进程号.
和$$
在某些场景不同; 变量制度; 可unset
$ cat test.sh
#!/bin/bash
echo $$ $BASHPID
(
echo $$ $BASHPID
)
$ ./test.sh
11199 11199
11199 11200
根据结果可以看到BASHPID
是实际上下文的, 而$$
则是预处理阶段替换;
BASH_ALIASES
一个map
类型, 添加会修改这个值, 但是修改这个值不会导致alias
改变;
当前环境中定义的alias
, 注意alias
不会继承, 可以自定义
$ cat test.sh
#!/bin/bash
for keys in ${!BASH_ALIASES[@]};
do
echo "$keys:${BASH_ALIASES[$keys]}"
done
$ source test.sh
grep:grep --color=auto
egrep:egrep --color=auto
alert:notify-send --urgency=low -i "$([ $? = 0 ] && echo terminal || echo error)" "$(history|tail -n1|sed -e 's/^\s*[0-9]\+\s*//;s/[;&|]\s*alert$//')"
fgrep:fgrep --color=auto
la:ls -A
ll:ls -alF
l:ls -CF
ls:ls --color=auto
自己定义
$ cat test.sh
#!/bin/bash
alias ll='ls -l'
for keys in ${!BASH_ALIASES[@]};
do
echo "$keys:${BASH_ALIASES[$keys]}"
done
$ ./test.sh
ll:ls -l
BASH_ARGC
shopt -s extdebug
模式才能试用
数组类型: 栈的形式管理个数和参数, FUNCNAME, BASH_SOURCE
则分别对应调用栈函数和文件, BASH_LINENO
则对应行号;
记录当前每个函数调用栈的参数个数; BASH_ARGV
则同理, 记录每个函数调用栈的所有参数;
$ cat test.sh
#!/bin/bash
shopt -s extdebug
function B
{
echo ${BASH_ARGC[@]}
echo ${BASH_ARGV[@]}
}
function A
{
B 1 2 3
}
A 4 5 6 7
$ ./test.sh
3 4
3 2 1 7 6 5 4
完整堆栈获取
$ cat test.sh
#!/bin/bash
shopt -s extdebug
function B
{
CUR=0
for ((i=0; i < ${#BASH_SOURCE[@]};i++));
do
echo -n "\$$i : ${FUNCNAME[$i]} "
if [[ ! -z "${BASH_ARGC[$i]}" ]];
then
let CUR+=${BASH_ARGC[$i]}
for((j=0;j<${BASH_ARGC[$i]};j++))
do
echo -n "${BASH_ARGV[$CUR-$j-1]} "
done;
echo " : ${BASH_SOURCE[$i]} : ${BASH_LINENO[$i]}"
else
echo ";"
fi
done;
}
function A
{
B 1 2 3
}
A 4 5 6 7
$ ./test.sh
$0 : B 1 2 3 : ./test.sh : 26
$1 : A 4 5 6 7 : ./test.sh : 28
$2 : main ;