Linux 中的 $* 与 $@ 位置变量

Linux 中的 $* 与 $@ 位置变量

Linux 中 $* 和 $@ 位置变量有什么区别?我读到过一些文章说使用 $* 存在安全风险。这是真的吗?

答案1

基本上它们是相同的,除了变量用双引号括起来的情况。然后$*扩展为一个单词并扩展为单独的单词。我认为存在安全风险$@的说法没有任何道理。$*

来自 bash 手册页:

   *      Expands  to  the positional parameters, starting from one.  When
          the expansion occurs within double quotes, it expands to a  sin-
          gle word with the value of each parameter separated by the first
          character of the IFS special variable.  That is, "$*" is equiva-
          lent to "$1c$2c...", where c is the first character of the value
          of the IFS variable.  If IFS is unset, the parameters are  sepa-
          rated  by  spaces.   If  IFS  is null, the parameters are joined
          without intervening separators.
   @      Expands to the positional parameters, starting from  one.   When
          the  expansion  occurs  within  double  quotes,  each  parameter
          expands to a separate word.  That is, "$@" is equivalent to "$1"
          "$2"  ...   If the double-quoted expansion occurs within a word,
          the expansion of the first parameter is joined with  the  begin-
          ning  part  of  the original word, and the expansion of the last
          parameter is joined with the last part  of  the  original  word.
          When  there  are no positional parameters, "$@" and $@ expand to
          nothing (i.e., they are removed).

相关内容