shell里 $@ 和 $* 的区别

本文介绍了Shell脚本中变量的定义和使用,包括如何引用、查看、取消变量,以及变量的作用域。特别讨论了$@和$*的区别,它们在处理位置参数时的不同表现,展示了如何通过示例来理解和运用这两个特殊变量。此外,还提到了shift命令在调整位置参数时的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

变量的定义

在Shell中,通常情况下用户可以直接使用变量,而毋需先进行定义,当用户第一次使用某个变量名
时,实际上就同时定义了这个变量,在变量的作用域内,用户都可以使用该变量。

引用变量 变量名或者 变量名 或者 变量名或者{变量名}
查看变量:echo $变量名,set(可查看所有变量:包括自定义变量和环境变量),env显示全局变量,
declare输出所有的变量、函数、整数和已经导出的变量。
取消变量unset 变量名
作用范围:仅在当前shell中有效

**

$@ 和 $* 的区别

**
$*| 以"参数1 参数2 参数3…"的形式返回所有参数的值 |
$@| 以“参数1”“参数2”“参数3”…的形式返回所有的值 |

$@ 和 $*的区别示例

[root@localhost test]# set -- "i have" a cat #利用set命令设置位置参数 
[root@localhost test]# echo $# 
3
[root@localhost test]# echo $* 
i have a cat 
[root@localhost test]# echo $@
i have a cat 
[root@localhost test]# for i in $*;do echo $i;done
i
have
a
cat
[root@localhost test]# for i in $@;do echo $i; done
i
have
a
cat
[root@localhost test]# for i in "$*";do echo $i;done
i have a cat
[root@localhost test]# for i in "$@";do echo $i;done
i have
a
cat
[root@localhost test]# shift #使用该指令可将位置参数左移一位 
[root@localhost test]# echo $1 
a
[root@localhost test]# shift 
[root@localhost test]# echo $1 
cat
<think>好的,我现在需要回答用户在Shell脚本中$@"$@"的区别这个问题。首先,我得回忆一下自己对这两个符号的理解。 我记得在Shell脚本中,$@$*都是用来表示所有传递给脚本的参数。不过它们之间有些不同。根据用户提供的引用[1],$@是传给脚本的所有参数的列表,而$*是以一个单字符串显示所有参数。但用户现在问的是$@"$@"的区别,这可能涉及到引号的使用对参数处理的影响。 接下来,我需要确认当变量被双引号包围时会发生什么。在Shell中,双引号会阻止通配符扩展单词分割,但允许变量扩展。所以,当使用"$@"时,每个参数都会被当作独立的带引号的字符串,这样就能正确处理包含空格或特殊字符的参数。而单独的$@在没有引号的情况下,参数可能会被分割,导致意外的行为。 举个例子,假设有三个参数:"a b"、c、d。使用$@的话,可能被展开为三个参数,但如果有空格的话,比如第一个参数是"a b",那么不带引号的$@可能会拆分成ab两个参数。而使用"$@"则会保留"a b"作为一个整体参数,这样在传递参数时就不会被拆开。 另外,根据引用[1]提到的$@是参数列表,可能当用双引号括起来时,它能够正确地展开为多个独立的参数,每个参数都保持原样。而如果不加引号,可能会因为Shell的单词分割而导致参数被错误地拆分。 总结一下,区别在于参数的保留方式:"$@"能够正确处理带有空格或特殊字符的参数,保持每个参数的完整性,而$@在不加引号时可能会导致参数的分割。这在编写需要处理复杂参数的脚本时尤为重要,比如处理文件名或包含空格的字符串时。</think>在Shell脚本中,`$@` `"$@"` 的区别主要在于**参数的分割与保留方式**,具体表现如下: --- ### 1. `$@`(未加引号) - **行为**:将参数列表展开为独立的单词,但**不保留原始参数的边界**。 - **问题**:若参数包含空格或特殊字符,会被Shell进一步分割。例如,参数为 `"hello world"` 时,会被拆分为 `hello` `world` 两个参数。 - **示例**: ```bash # 脚本内容 test.sh for arg in $@; do echo "[$arg]" done # 执行命令 ./test.sh "a b" c "d e" ``` **输出**: ``` [a] [b] [c] [d] [e] ``` --- ### 2. `"$@"`(加双引号) - **行为**:将参数列表展开为**独立的带引号的字符串**,严格保留每个参数的原始值。 - **优势**:正确处理包含空格、制表符或特殊字符的参数,避免意外分割。 - **示例**: ```bash # 脚本内容 test.sh for arg in "$@"; do echo "[$arg]" done # 执行命令 ./test.sh "a b" c "d e" ``` **输出**: ``` [a b] [c] [d e] ``` --- ### 关键对比表 | 形式 | 参数分割行为 | 适用场景 | |---------|---------------------------|----------------------------| | `$@` | 可能因空格/特殊字符分割 | 明确不需要保留参数边界时 | | `"$@"` | 严格保留参数原始值 | 需安全传递复杂参数(如文件名)| --- ### 典型应用场景 - **`"$@"`**:在包装脚本或需要逐字传递参数时(如调用其他命令): ```bash # 正确传递所有参数给另一个命令 git commit -m "$@" ``` - **`$@`**:明确希望分割参数时(如简单遍历单词)。 --- ### 扩展知识 - `$*` 与 `"$*"`:`$*` 将所有参数合并为单个字符串,`"$*"` 合并后作为一个整体(默认以空格分隔,可通过 `IFS` 修改)[^1]。 - 参数数量:`$#` 表示参数个数,`$0` 是脚本名,`$1`/`$2` 是位置参数,`$$` 是进程ID,`$?` 是退出状态。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值