AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 519398
Accepted
Căcărău
Căcărău
Asked: 2019-05-17 17:14:21 +0800 CST2019-05-17 17:14:21 +0800 CST 2019-05-17 17:14:21 +0800 CST

跟随重定向时未按预期执行 $-expansions

  • 772

似乎bash并且zsh将在子进程中执行变量和算术扩展

a) 他们遵循重定向运算符,如<,或.>>><<<

b)他们所属的命令不是内置或函数。

bash -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
0
zsh -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
0

ksh -c 'i=0; /bin/echo > $((i=7)).txt; echo $i'
7

ksh上面就像除bashor之外的任何其他 shell zsh。

这与算术扩展无关:类似地,同样的事情发生在

unset i; /bin/echo >${i:=7}.txt; echo $i

只会在or7以外的 shell 中打印。bashzsh

然而,好像这还不够糟糕,行为在bash和之间以任何可理解的方式不一致zsh:

bash -c 'i=0; command echo > $((i++)).txt; echo $i'
1
zsh -c 'i=0; command echo > $((i++)).txt; echo $i'
0

bash -c 'i=0; i=$i /usr/bin/printenv i > $((++i)).bash; echo $i; cat *.bash'
0
0
zsh -c 'i=0; i=$i /usr/bin/printenv i > $((++i)).zsh; echo $i; cat *.zsh'
0
1

所以,我的问题是:标准是怎么说的?这可以接受吗?

我能够找到很多关于变量赋值的信息,比如KEY=val cmd它们可能会或可能不会“影响当前的执行环境”,但没有关于重定向、$扩展和外部命令之间的交互。

并且它不可能也适用于作为$-expansions 的一部分完成的变量分配,因为无论是外部命令还是内置命令,都会ls $((i=2+3))导致在所有 shelli中设置为。5ls

bash shell
  • 1 1 个回答
  • 104 Views

1 个回答

  • Voted
  1. Best Answer
    Gilles 'SO- stop being evil'
    2019-05-18T10:41:01+08:002019-05-18T10:41:01+08:00

    这是未指定的,因此每个外壳都可以做它想做的事情,并且不必记录细节。(从历史的角度来看,这是未指定的,因为不同的贝壳做不同的事情。)从技术上讲,贝壳可以翻转硬币。在实践中,在单独的环境中运行和不运行的细节可能取决于在某些情况下所做的优化,例如取决于命令是否是内置的,取决于重定向是否是 to/from /dev/null,取决于陷阱是否处于活动状态,取决于是否set -e生效,取决于命令是否是列表中的最后一个,等等。

    来自SUSv4 (POSIX.1-2008) “Shell and Utilities” — §2.9.1 “简单命令”:

    如果命令名称不是特殊的内置实用程序或函数,则应为命令的执行环境导出变量分配,并且不应影响当前执行环境,除非是在步骤 4 中执行的扩展的副作用。在这种情况下,它是未指定的:

    • 分配对于步骤 4 中的后续扩展是否可见

    • 作为这些扩展的副作用进行的变量分配对于步骤 4 中的后续扩展或当前 shell 执行环境中的后续扩展是否可见,或两者兼而有之

    澄清一下:“第 4 步”包括参数扩展(例如${i:=7})和算术扩展(例如$((i=7)))。“不应影响当前执行环境”的变量扩展是命令前面的变量扩展,例如i=7 ls. 因此,本段除其他外说,如果参数扩展或变量扩展修改了变量的值,则未指定在命令返回后这是否有效。

    在实践中,shell 通常通过先分叉并在子 shell 中执行重定向来将重定向应用到外部命令。但是它们的不同之处在于它们是在创建子shell之前还是之后确定重定向的目标。

    • 3

相关问题

  • 从文本文件传递变量的奇怪问题

  • 虽然行读取保持转义空间?

  • 如何将带有〜的路径保存到变量中?

  • `tee` 和 `bash` 进程替换顺序

  • 运行一个非常慢的脚本直到它成功

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve