- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在考虑如何在我自己的一个程序中实现某个功能时,我一直想知道 bash 如何在内部处理以下性质的管道:
yes | sleep 10
这显然什么都不做,但我不明白这怎么不会导致错误。我本以为:
因为 sleep
不从 stdin 读取,连接两个进程的管道将被填满并导致 yes
在尝试写入 now 时无限期阻塞满管
如果使用非阻塞 IO,如果首先执行 yes
并在 sleep
进程运行之前写入管道,则应该发生错误,因此没有进程连接到管道的读取端
我想这是我的一些重大误解。我已经尝试查看 bash 源代码,但我无法理解。
最佳答案
这是运行 shell 命令时实际发生的事情 yes |睡 10
。
首先 shell 创建一个 anonymous pipe使用 pipe
system call . pipe
系统调用打开两个文件描述符,分别是管道的读端和写端。写入端的任何内容都可供读取端读取。
在此之后,shell 使用 fork
system call 创建两个子进程.两个 child 并排跑。
execve
system call用yes
的代码图替换本过程中的代码图。yes
会尽可能长时间地写入管道。如果管道的读取端没有事件的 read
调用,则 write
调用只会阻塞。 (实际上有一个小缓冲区,write
会在阻塞之前填满,但这在这里无关紧要。)execve
系统调用将本进程中的代码镜像替换为sleep
的代码镜像。sleep
程序在 10 秒内什么都不做。wait
system call)。一旦 10 秒结束,运行 sleep
的进程就会退出。此时,管道的读端不再在任何进程中打开。当一个进程试图写入一个读端在任何进程中都没有打开的管道时,内核会发送一个SIGPIPE
。向写入过程发出信号。因此,运行 yes
的进程被 SIGPIPE 信号杀死。
此时,shell 检测到它在管道两边的子进程已经退出。管道命令返回右侧的状态,即 0(sleep
成功退出)。
because sleep does not read from stdin, the pipe connecting both processes would fill up and cause yes to block indefinitely when it attempts to write to the now full pipe
这是正确的。
if non-blocking IO is used, errors should occur if yes is executed first and writes to the pipe before the sleep process is even run and thus no process is connected to the read end of the pipe
这在几个地方是不正确的。 yes
不使用非阻塞 IO。它与 sleep
并行执行,而不是首先执行。从来没有任何时间点没有进程连接到管道的读取端,直到 sleep
退出。根据时间的不同,yes
可能会在 sleep
开始执行之前开始写入,甚至可能在 sleep
程序的子进程被 fork 之前, 但当 pipe
调用返回时,读取端打开,同时写入端打开。
关于bash - 为什么 "yes | sleep 10"管道不会失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52456616/
我用 IntelliJ IDEA 2021.1 CE 在 流行!_OS 20.04 与 bash 5.0.17 . 问题造句:我将IntelliJ终端设置为/bin/bash通过 IntelliJ 设
给定如下命令: bash --shortcuts 我想显示一个快捷方式列表,就像在这个页面上一样: http://www.skorks.com/2009/09/bash-shortcuts-for-m
我有一个脚本可以操作数据、创建参数并将它们发送到第二个脚本。其中一个参数包含一个空格。 脚本1.sh: args=() args+=("A") args+=("1 2") args+=("B") .
我的脚本的“只运行一次”版本的一个非常简单的示例: ./myscript.sh var1 "var2 with spaces" var3 #!/bin/bash echo $1 #output: va
我想了解数字( double )在 bash 中是如何表示的,以及当我在 bash 中以十六进制格式打印数字时会发生什么。 根据 IEEE 754 标准,double 应由 64 位表示:52 位(1
我试图在 bash -c "..." 命令中获取 bash 脚本,但它不起作用。 如果我在 bash -c "..." 之外运行命令,它会起作用。 我需要使用 bash -c "..." 因为我想确保
如何检测我的 bash shell 中是否加载了 bash 补全包?从 bash-completion 的 2.1 版(包含在 Debian 8 中)开始,除了 BASH_COMPLETION_COM
我的 bash_profile 中有一个投影函数。现在我试图从 bash 脚本中调用这个函数,但是我得到了一个未找到的错误。如何使投影函数对 bash 脚本可见? 最佳答案 必须导出函数 export
我正在编写一个 bash 脚本,它接受许多命令行参数(可能包括空格)并通过登录 shell 将它们全部传递给程序 (/bin/some_program)。从 bash 脚本调用的登录 shell 将取
当我创建一个新的 bash 进程时,提示符默认为一个非常简单的提示符。我知道我可以编辑 .bashrc 等来更改它,但是有没有办法使用 bash 命令传递提示? 谢谢! 最佳答案 提示由 PS1、PS
好的,我希望这个问题有一定道理,但是 bash shell 和 bash 终端之间有什么区别?例子。当我第一次打开终端时,会提示我当前的目录和用户名。在终端窗口标题中显示 -bash- ,当我键入 e
我是 SBCL 的新手,我正在尝试从 bash 终端运行存储在文本文件中的 Lisp 脚本。 这是我在文件开头写的内容 http://www.sbcl.org/manual/#Running-from
我知道我们可以在 bash 中使用将十六进制转换为十进制 #!/bin/bash echo "Type a hex number" read hexNum echo $(( 16#$hexNum ))
我正在尝试在 bash 脚本中自动完成文件夹名称。如果我输入完整的文件夹名称,一切正常,但我不知道如何自动完成名称。有什么想法吗? repo() { cd ~/Desktop/_REPOS/$1 }
我想检查远程网站上的一些文件。 这里是bash命令生成计算文件md5的命令 [root]# head -n 3 zrcpathAll | awk '{print $3}' | xargs -I {}
是否有任何内置函数可以使用 bash shell 脚本从给定日期获取下周日(下周一、下周二等)?例如,2014 年 9 月 1 日之后的第一个星期日是什么时候?我预计 2014 年 9 月 7 日。
我一直在尝试根据表格重命名一些特定文件,但没有成功。它要么重命名所有文件,要么给出错误。 该目录包含数百个以长条形码命名的文件,我只想重命名包含模式 _1_ 的文件。 例子 barcode_1_bar
bash 中有没有办法用变量的内容替换文本文件中的占位符? 例如,我想发送一封电子邮件通知,如下所示: Dear Foo, Alert: blah blah blah blah blah blah
我有一个 bash 脚本,它在某些字符串上附加了一个重音字符,导致它失败,我找不到这些字符在哪里或如何进入那里。 这是一些示例输出: mv: cannot move â/tmp/myapp.zipâ
这个问题在这里已经有了答案: How do I place stdout on edit line? (1 个回答) Can a bash script prepopulate the prompt
我是一名优秀的程序员,十分优秀!