fork() 在 C++ 中的工作
Working of fork() in C++
我在C++有这个程序。
#include <iostream>
#include <unistd.h>
#include <sys/types.h>
using namespace std;
int main()
{
cout<<"*n";
fork();
cout<<"An";
fork();
cout<<"Bn";
fork();
cout<<"Cn";
return 0;
}
输出为:
*
A
B
C
*
A
B
C
我认为应该是:
*
A
B
C
A
B
C
B
C
C
说明:"*"应通过一个过程打印。现在,在fork()
之后,应该打印2个"A",子"B"和"C"。
链接到代码
根据对该问题的评论,答案是 ideone.com 在线编译器中的fork
只是将您限制为进程的一个实例,并缓冲您的输出。
更新:实际上,它也在撒谎:http://ideone.com/oXqqwM 表明fork()
声称成功,但只有第一个会生成您的流程的新副本。
我怀疑如果你检查fork()
的返回值,你会得到一些关于你所看到的令人惊讶的行为的线索——除了第一个之外,所有的行为都会返回 -1——如果你使用std::endl
,你可能会避免第一个*
。
预期的结果是,此时每个fork()
都会复制正在运行的进程,因此与前一个字符相比,您希望看到每个字符的两倍,除了缓冲意味着在fork()
时缓冲区中可能仍有以前的字符。
因此,预计有 1 个或多个"*"、2 个或更多"A"、4 个或更多"B"或 8 个或更多"C",但如果fork()
失败,数字将被封顶。
对 1 "*"、"2 个 A"、3 个"B"和 4 个"C"的期望表明你忽略了从fork()
出来的两个过程都会到达下一个fork()
,所以你加倍,而不是递增一个。
所以...如果您得到不止一个*
那么就会发生一些奇怪的事情,我怀疑它是特定于实现的...... fork
将为每个子进程提供文件描述符的副本,包括stdout
...所以在你的实现中,它也获得了 std::cout 流的有效副本......它已经有一个加载了*
的缓冲区......
我认为如果您更改程序以包含刷新,您将看到与我相同的操作:
#include <iostream>
#include <unistd.h>
#include <sys/types.h>
using namespace std;
int main()
{
cout<< "*n";
flush(cout);
fork();
cout<<"An";
flush(cout);
fork();
cout<<"Bn";
flush(cout);
fork();
cout<<"Cn";
flush(cout);
return 0;
}
- QSqlquery prepare()和bindvalue()不工作
- 导入库可以跨dll版本工作吗
- 以螺旋方式打印矩阵的程序.(工作不好)
- 对象指针在c++中是如何工作的
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- VSOMEIP-2个设备之间的通信(TCP/UDP)不工作
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++为线程工作动态地分割例程
- 为什么我的 std::ref 无法按预期工作?
- 布尔比较运算符是如何在C++中工作的
- SampleConsensusPrerejective(ext.RANSAC)是如何真正工作的
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 为什么std::condition_variable notify_all的工作速度比notify_one快(对于随机请
- <<操作员在下面的行中工作
- 有人能解释一下为什么下界是这样工作的吗C++的
- ExtractIconEx:可以工作,但偶尔会崩溃
- C++中的memset函数工作不正常
- 当我在第一个循环中使用"auto"时,它工作正常,但是使用"int"它会给出错误,为什么?
- 链表c++插入,所有情况都已检查,但没有任何工作
- 为什么stream::忽略未按预期工作