- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我一直在努力理解命令dup2()
、exec()
和管道的概念。
我要达到的目标是:
将程序X的输出通过管道传送到程序Y的输入。
一些基本的东西,比如who | sort
有一个父级和两个子级,其中子级负责执行程序,父级将程序传递给子级。
以下是我对管道的一些不理解:
P1)管道被视为文件,应该是单向的,但是什么阻止了我将一个管道用于多个单向通信信道?
所以,假设我有pipe1
和三个进程(P
-父进程-C1
,C2
,子进程),它们通过分叉打开管道。所有这些进程都使用文件描述符。
假设我们做的一切都是正确的,关闭未使用的管端,P
现在会向C1
写入一些内容。再次使用管道在C1
和C2
之间进行通信有什么问题?
就在写这个问题的时候,我突然想到一个想法:当许多进程可能同时打开它(两个进程正在阻塞以获取读取)时,谁从中读取数据,即系统不能确定谁想读取写入其中的缓冲数据,这是否有问题?如果是,这是如何在系统中实现的?
我真的试着去理解这个概念,所以请容忍我。
要将这个问题应用到现实生活中,我要处理的是一些伪代码:
P:P
关闭不需要的读取结束pipe1
通过P
向C1
发送程序参数('who')pipe1
关闭写入端
C1类:
P
从
P
的读取端读取参数
C1
pipe1
s标准输出到
C1
dup2()
关闭
pipe1
的两端(因为我们已经欺骗了它)
C1
pipe1
s程序(“谁”)
指挥2:
C1
execvp()
s从
C2
读取到
dup2()
的结尾,以便获取将要执行的程序的输入
pipe1
关闭
stdin
的两端
C2
在
pipe1
ed
C2
中的
stdin
上等待输入
有此输入的
C1
dup
s程序('sort')
现在,如果我按上面描述的那样做,我就没有运气了。
但是,如果我引入另一个管道,它看起来像这样:
P:
pipe1
关闭不需要的管道的两端
C2
execvp()
关闭不需要的读取结束
pipe2
通过
P
向
pipe2
发送程序参数('who')
P
关闭写入端
C1类:
pipe1
关闭读取结束
P
从
C1
的读取端读取参数
pipe1
P
s标准输出到
P
C1
关闭
pipe2
的写入端
C1
关闭
pipe1
的两端--此子项中有多余的
C1
dup2()
s程序(“谁”)
指挥2:
pipe2
C1
s读取结束
pipe2
到
C1
pipe1
关闭
pipe2
的两端
pipe1
在
C1
ed
execvp()
中的
C2
上等待输入
dup2()
使用此输入执行程序
假设管道不应在多个进程中重用,因为系统可能不确定“为谁服务”,这一假设是否正确?或者有其他原因吗?
最佳答案
管道主要是为一对一的交流设计的——一个作者,一个读者。虽然没有什么可以阻止拥有尽可能多的读者和作者,但这种行为通常会使这一点变得不太有用,特别是对于多个读者:
从管道读取数据是一种破坏性操作:通过管道发送的每个字节都将被其中一个读卡器读取,无论谁先获取它。如果要广播某些信息,则需要使用不同的IPC机制或显式复制数据(如tee
命令)。
如果有多个作家,他们的作品会以某种不可预知的方式穿插在一起。唯一的保证是大小小于或等于cc的写操作是原子的。
如果写入程序的数量降至零,则读取器将看到文件结束条件。
在您描述的体系结构中,有两个独立的通信通道:P向C1发送PIPE_BUF
命令,C1向C2发送运行who
命令的输出。在shell脚本中,这类似于
echo who | { read command; exec command; } | sort
who
。
关于c - 与dup2(),exec()和管道混淆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29858707/
我正在尝试设置 rbenv: https://github.com/sstephenson/rbenv#section_2 我有一个问题:我必须在一切之前使用 rbenv exec 所以现在我要做 b
我已经使用我们的应用程序创建了图像,运行该图像后,我可以看到还创建了 docker 容器,当我尝试进入 docker 容器时,出现以下错误,请您在这里帮助我。 """"OCI runtime exec
这post on javapapers.com显示如何运行 JMH通过键入 mvn exec:exec 在 Maven 中进行基准测试。在 Maven 中运行 JMH 非常方便,因为您可以轻松地从 E
因为我是 shell 脚本的新手,exec命令总是让我感到困惑,同时用 while 探索这个话题循环触发了以下 4 个问题: 下面的语法 1 和 2 有什么区别 语法 1: while read LI
湖一看这两条线 案例 1 set cvsUpdStr [exec cvs -qn upd] 案例 2 set cvsUpdStr [exec cvs -qn upd >&@stdout] 对于第一种情
我有一个配置为使用 Maven 构建和运行的项目。该项目取决于平台特定的 native 库,我正在使用发现的策略 here管理这些依赖项。 本质上,特定平台的 .dll 或 .so 文件被打包到 ja
我发现 tcl exec 命令首先从标准输出返回字符串,然后是标准错误。例如,我下面的“测试脚本”按以下顺序生成消息: puts "test started" puts stderr "some no
我有 rpc error: code = 13 desc = invalid header field value "oci runtime error: exec failed: cannot ex
过去 2 天我遇到了一个问题。 我正在运行一个 tcl 脚本(用于 eggdrop),该脚本在被触发时执行本地 shell 命令(子进程),如果命令成功,它会输出结果。但是,如果命令不成功,我会收到错
假设我有一个像这样的 TCL 脚本: exec ls -l 现在这将打印出当前目录的内容。我需要将该输出作为字符串并解析它。我怎么能做到这一点? 最佳答案 exec返回输出,因此只需为其设置一个变量:
我正在尝试在 PHP 中使用 GNUPLOT 绘制正弦图,但是当我使用 exec 绘制该图时出现此错误: Warning: exec() [function.exec]: Cannot execute
我正在尝试 mvn exec:exec (或 mvn exec:java )使用类路径中的本地 jar 运行我的程序。但是 jar 无法加载: Exception in thread "main" j
我在最新的 Docker CLI 文档中注意到 Docker CLI 命令列表已经扩展。 如果我使用 码头执行 早些时候在容器内启动可执行文件现在我也可以使用 docker 容器执行 命令。 dock
这个问题在这里已经有了答案: Call to a member function exec() on a non-object error in PHP [duplicate] (1 个回答) 关闭
手册页说“exec() 系列函数用新的过程镜像替换当前的过程镜像。”但我不太明白“用新过程图像替换当前过程图像”的含义。比如exec成功,perror就达不到 execl("/bin/ls", /*
手册页说“exec() 系列函数用新的过程镜像替换当前的过程镜像。”但我不太明白“用新过程图像替换当前过程图像”的含义。比如exec成功,perror就达不到 execl("/bin/ls", /*
我正在 UrbanCode Deploy Shell 步骤中执行以下命令。我想要的是针对找到的所有文件运行 Util.sh。 find . -type f -exec ls -al {} \; fin
仅当将“-p”添加到 org.codehaus.mojo:exec-maven-plugin:1.6.0:exec 插件时,以下 pom.xml 执行才会失败,删除此参数后它运行正常,但我需要争论,有
我正在尝试进入 Maven 并开始编写一个小型库。作为库代码的一部分,我想要一个小型演示 Java 应用程序,可以用来查看库在做什么以及如何使用它。现在真正让我烦恼的一件事是,为了执行该演示,我必须执
我是 maven 的新手,在通过 maven 运行类文件时遇到问题 它运行良好 mvn exec:java -Dexec.mainClass="com.test.Test" 但不是 mvn exec:
我是一名优秀的程序员,十分优秀!