操作系统:Linux,语言:纯C
我正在学习一般的C编程,以及在特殊情况下在UNIX下进行C编程.
printf()在使用fork()呼叫后,我发现了一个奇怪的(对我来说)函数的行为.
码
#include <stdio.h>
#include <system.h>
int main()
{
int pid;
printf( "Hello, my pid is %d", getpid() );
pid = fork();
if( pid == 0 )
{
printf( "\nI was forked! :D" );
sleep( 3 );
}
else
{
waitpid( pid, NULL, 0 );
printf( "\n%d was forked!", pid );
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
产量
Hello, my pid is 1111
I was forked! :DHello, my pid is 1111
2222 was forked!
Run Code Online (Sandbox Code Playgroud)
为什么第二个"Hello"字符串出现在子输出中?
是的,这正是父母在开始时与父母一起打印的内容pid …
可能重复:
在linux gcc中使用fork()
#include <stdio.h>
void main ()
{
printf ("ciao");
fork ();
}
Run Code Online (Sandbox Code Playgroud)
我有一些关于C优化的想法,但我不确定.希望你知道答案.
根据我的理解fork(),这应该打印"Hello,World!" 曾经,因为之前只有一个过程fork被调用.但是,它会打印两次.奇怪的是,如果我添加一个\n字符串或使用puts()而不是printf(),它只打印一次.
#include<unistd.h>
#include<stdio.h>
int main() {
printf("Hello, World!");
fork();
}
Run Code Online (Sandbox Code Playgroud)