- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个问题,我需要编写一个小的 c 程序来打印出由三个进程给出的随机数,这些进程自己只打印一个数字 20 次。
输出应该类似于 0122102021012021120...
以及从父进程完成的内容。
我只得到这样的输出:
00000000000000000000ready11111111111111111111readyready22222222222222222222readyreadyready
而且我不知道该怎么做——我似乎不理解 fork() 系统背后的基本逻辑;)
我的代码是:
1 #include <stdio.h>
2 #include <unistd.h>
3 #include <stdlib.h>
4
5 void printfXtimes(int a, int b){
6 int i;
7 for(i=0;i<b;i++){
8 printf("%i",a);
9 sleep(1);
10 }
11 }
12
13 void main(){
14 for(int kid = 0; kid < 3; ++kid) {
15 int pid = fork();
16 if(pid < 0){
17 exit(EXIT_FAILURE);
18 }else if (pid > 0){
19 /* Parent process */
20 printf("ready");
21 }else{
22 /* Child process */
23 printfXtimes(kid,20);
24 exit(EXIT_SUCCESS);
25 }
26 for (int kid = 0; kid < 3; ++kid) {
27 int status;
28 pid_t pid = wait(&status);
29 }
30
31 }
32 }
这里有什么问题吗? :/该任务被认为是“简单的”...我不明白...
最佳答案
适度可行的代码:
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
static void printfXtimes(int a, int b)
{
for (int i = 0; i < b; i++)
{
printf("%i\n", a);
usleep(10000);
//sleep(1);
}
}
int main(void)
{
for (int kid = 0; kid < 3; ++kid)
{
int pid = fork();
if (pid < 0)
{
exit(EXIT_FAILURE);
}
else if (pid > 0)
{
/* Parent process */
printf("PID %d ready\n", pid);
}
else
{
/* Child process */
printfXtimes(kid, 10);
exit(EXIT_SUCCESS);
}
}
for (int kid = 0; kid < 3; ++kid)
{
int status;
int corpse = wait(&status);
printf("PID %d exited 0x%.4X\n", corpse, status);
}
}
注意事项:
fork()
时,main()
的正确返回类型是 int
,而不是 void
.您可以在 Windows 上使用 void main()
;在其他任何地方,它都是错误的(几乎所有其他地方——特定系统可以将其记录为 OK,就像 Windows 一样)。参见 What should main() return in C and C++? printf()
anomaly after fork()
)。示例输出(无管道):
PID 34795 ready
PID 34796 ready
0
1
2
PID 34797 ready
0
1
2
0
1
2
0
1
2
0
1
2
0
1
2
1
2
0
1
0
2
1
0
2
1
2
0
PID 34795 exited 0x0000
PID 34797 exited 0x0000
PID 34796 exited 0x0000
示例输出(通过管道传输到 sed
):
0
0
0
0
0
0
0
0
0
0
PID 34789 ready
1
1
1
1
1
1
1
1
1
1
PID 34789 ready
PID 34790 ready
2
2
2
2
2
2
2
2
2
2
PID 34789 ready
PID 34790 ready
PID 34791 ready
PID 34789 exited 0x0000
PID 34791 exited 0x0000
PID 34790 exited 0x0000
如果您已经阅读并理解了“fork()
之后的printf()
异常”问题,您应该了解行缓冲和全缓冲,以及输出via sed
应该是可解释的(特别是,为什么有额外的 PID nnnnn ready
消息副本)。
关于c - 如何使用运行异步的 fork 创建 3 个进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37424841/
有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_ / \ /
我是一名优秀的程序员,十分优秀!