- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想解决某个问题,但我不知道如何正确解决。我必须在链中创建 N 个进程,在我完成所有这些之后,初始进程将随机一个数字并将其写入管道,其他进程从管道中读取该数字,它们随机化一个数字并从中减去结果读取的数字,将其写回管道等。这是我试过的
#include <string.h>
#include <sys/types.h>
#include <stdlib.h>
#include <time.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/wait.h>
#define P_READ 0
#define P_WRITE 1
void forker(int nprocesses, int** pipes, int fd[2])
{
pid_t pid;
int buf;
if(nprocesses > 0)
{
if ((pid = fork()) < 0)
{
perror("fork");
}
else if (pid == 0)
{
//Child
printf("Child %d created PID : %d , PPID : %d\n", nprocesses-1, getpid(), getppid());
int i = nprocesses - 1;
time_t t;
srand((int)time(&t) % getpid()); // get unique seed for every child
int r = (rand() % 11) + 10;
if (i==0) {
read(fd[P_READ], &buf, sizeof(int));
close(fd[P_READ]);
}else{
read(pipes[i-1][P_READ], &buf, sizeof(int));
close(pipes[i-1][P_READ]);
}
close(pipes[i][P_READ]);
buf -= r;
printf("%d|%d|%d|%d\n", buf, r, getpid(), getppid());
write(pipes[i][P_WRITE], &buf, sizeof(int)); // write
close(pipes[i][P_WRITE]);
printf("Child %d end\n", nprocesses-1);
}
else if(pid > 0)
{
forker(nprocesses - 1, pipes, fd);
}
}
}
int main (void)
{
int status = 0;
srand(time(NULL));
pid_t pid = getpid();
pid_t parent = getpid();
pid_t wpid;
int n, fd[2], buf;
printf("Please enter how many processes you want(between 6 and 15): ");
scanf("%d", &n);
while ( n < 6 || n > 15)
scanf("%d", &n);
int **pipes = (int **)malloc(n * sizeof(int*));
for(int i = 0; i < n; i++) pipes[i] = (int *)malloc(2 * sizeof(int));
printf("I'm parent - my pid is %d\n",pid);
pipe(fd);
for(int i=0; i<n; i++) {
if(pipe(pipes[i])) {
printf("pipe error");
return -1;
}
}
forker(n, pipes, fd);
if(parent == getpid()) {
close(fd[P_READ]);
buf = (rand() % 9001) + 1000;
printf("The initial number is %d created by process with pid : %d\n", buf, getpid());
write(fd[P_WRITE], &buf, sizeof(int));
close(fd[P_WRITE]);
}
while ((wpid = wait(&status)) > 0); // WAIT
if (pid == getpid()) printf("End of parent and my pid was %d\n", pid);
return 0;
}
输出看起来像这样:
Please enter how many processes you want(between 6 and 15): 10
I'm parent - my pid is 3827
Child 9 created PID : 3828 , PPID : 3827
Child 8 created PID : 3829 , PPID : 3827
Child 7 created PID : 3830 , PPID : 3827
Child 6 created PID : 3831 , PPID : 3827
Child 5 created PID : 3832 , PPID : 3827
Child 2 created PID : 3835 , PPID : 3827
Child 3 created PID : 3834 , PPID : 3827
The initial number is 1625 created by process with pid : 3827
Child 1 created PID : 3836 , PPID : 3827
Child 4 created PID : 3833 , PPID : 3827
Child 0 created PID : 3837 , PPID : 3827
1609|16|3837|3827
Child 0 end
1589|20|3836|3827
1573|16|3835|3827
Child 2 end
1559|14|3834|3827
Child 3 end
1543|16|3833|3827
Child 4 end
1530|13|3832|3827
Child 5 end
Child 1 end
1511|19|3831|3827
Child 6 end
1498|13|3830|3827
Child 7 end
1488|10|3829|3827
Child 8 end
1470|18|3828|3827
Child 9 end
End of parent and my pid was 3827
问题是,我不确定第一个数字是否在进程创建之前是随机的(但这不是这里的大问题)。最大的问题是初始进程创建了所有子进程并且它不是“链式”的。
最佳答案
首先fork你处理N次,然后生成随机数并传递给其他进程。所以将随机数的创建放在循环之外以 fork 主进程
关于c - 在链中 fork N 个进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43940717/
有3个 repo : 有 OpenAI Baselines 存储库:https://github.com/openai/baselines . 我有它的 fork :https://github.co
我试图了解在调用 fork() 后复制文件描述符的含义及其对争用的可能影响。 在“Linux 编程接口(interface)”24.2.1 (p517) 中: When a fork() is per
我对 systemd 如何跟踪主进程存在后仍然存在的主进程的子进程感兴趣? 最佳答案 Systemd 为此使用了 cgroups。在启动任何使用服务文件定义的可执行文件之前,systemd 会创建一个
这是输出--- 家长:我的pid是4525 parent :我 parent 的 pid 是 3350 parent 开始- 4525 3350 fork 前 fork 前 child 4526 45
我之前 fork 了 jockm/vert.x 并向他发送了拉取请求。现在我想 fork vert-x/vert.x (jockm/vert.x 的上游)并向他们发送不同的拉取请求。但是,当我单击“F
我想控制从 Perl 脚本派生的进程的名称 a。理想情况下它会像这样: ./forker.pl | ... | | fork("forked.pl"); |\ | \ | `--------\ |
我知道 fork() 在更高级别上做什么。我想知道的是这个—— 一旦有 fork 调用,trap 指令就会跟随并且控制跳转以执行 fork “处理程序”。现在,这个创建子进程的处理程序如何通过创建另一
我正在研究操作系统测验,但我不知道输出什么 if(fork()) fork() 会产生。有人可以解释吗? 我不明白这一行: if(fork()) 编辑: 我所说的“输出”是指如果执行此代码,将
这个问题在这里已经有了答案: Why does this program print "forked!" 4 times? (6 个答案) 关闭 3 年前。 在 C 中,fork() 函数将为父进程
有什么方法可以区分程序中不同 fork() 函数创建的子进程。 global variable i; SIGCHLD handler function() { i--; } handle() {
我正在重新开发一个系统,该系统将通过 http 向多个供应商之一发送消息。原来是perl脚本,重新开发很可能也会用perl。 在旧系统中,同时运行多个 perl 脚本,每个供应商运行 5 个。当一条消
Git 的新手,仍然有点困惑。我在 github 上 fork 了一个项目,想将项目所有者最近对原始项目所做的一些更改引入/merge 到我的 fork 中。这可能吗?该项目是只读的,但基本上,我想让
根据维基百科(可能是错误的) When a fork() system call is issued, a copy of all the pages corresponding to the par
我需要帮助了解如何在 Go 中妖魔化进程。 package main import ( "fmt" "os" ) func start() { var procAttr os.Pro
我已经执行了这段代码。我知道消息的顺序是任意顺序的(因为我明确没有使用信号量)我的程序流程如何?为什么? 父级被执行,因此“baz”被打印一次。有人可以解释为什么不打印“bar”吗?为什么我得到“fo
这个问题已经有答案了: Why does this program print "forked!" 4 times? (6 个回答) 已关闭 5 年前。 我对 fork 进程有疑问。我有一个代码是 i
我在弄清楚如何使用在不同进程之间创建的列表时遇到了麻烦。我所拥有的是: FileList.h - 我创建的列表 #include "Node.h" typedef struct FileList {
好吧,所以我一直在 stackoverflow 上查找这个问题,并且肯定在谷歌上搜索了半个小时,但我得到的答案似乎与我真正想做的事情几乎没有任何关系,希望有人能提供帮助我在这方面,代码如下: int
我正在尝试了解 fork-join 的工作原理。 维基百科有以下合并排序示例,其中左半部分被 fork ,右半部分由当前线程处理。 mergesort(A, lo, hi): if lo t
下面的代码输出了一系列的过程,它到底做了什么: _PARENT_ / \ /
我是一名优秀的程序员,十分优秀!