Chinaunix

标题: linux c语言多线程的问题 [打印本页]

作者: 大雄_重庆    时间: 2014-09-19 11:50
标题: linux c语言多线程的问题
#include<unistd.h>
#include<stdio.h>
int main()
{
pid_t pid;
if((pid=fork())==0)
{
sleep(1);
printf("child process!\n");
}
else
{
  sleep(5);
  printf("parent process!\n");
}
return 0;
}
麻烦大家帮我看下这段代码,为什么父进程sleep函数中休眠时间比子进程休眠时间长时,代码会正常退出。如图1所示!

但是子进程比父进程休眠时间长时,子进程休眠5S,父进程休眠1S,打印输出正常,但该程序不会结束,如图2。

子进程休眠结束后,加上exit(0),程序仍无法结束,如图3

1.png (16.51 KB, 下载次数: 28)

1.png

作者: zhaohongjian000    时间: 2014-09-19 13:47
程序其实已经结束了,不信你按下回车,或者切到别的终端用ps看看。

造成这个现象的原因就是,父进程结束了就回到了终端,所以bash才打印了那些东西,然后子进程结束,所以在原有基础上又输出了"child process!\n"。
作者: enskyfly    时间: 2014-09-19 17:20
回复 1# 大雄_重庆
是因为父进程比子进程先退出,导致子进程成了孤儿进程,之后被init进程收养,时间到了之后,子进程也退出


   
作者: 大雄_重庆    时间: 2014-09-19 20:20
回复 3# enskyfly

嗯啊。这个我知道,但是时间到了,不知道为什么还是显示一个小白块在跳动,回不到bash界面!
   
作者: 大雄_重庆    时间: 2014-09-19 20:21
回复 2# zhaohongjian000


    嗯啊。你说的是正确的,我试了!但不明白为什么那个小白块不会到bash呢,除非按下enter或者ctrl +c。能给解答下么。。。
作者: zhaohongjian000    时间: 2014-09-20 08:59
回复 5# 大雄_重庆

其实已经回到bash了,你说的小白块就是bash的光标,你可以不按回车,直接输入一个命令比如ls,然后回车执行。因为bash是每条命令执行完了,就输出一行命令提示符,所以你的程序中的父进程执行完了之后,就成了:
  1. user@machine:~/path $
复制代码
在上面这一行基础上,子进程退出,所以变成:
  1. user@machine:~/path $ child process!

复制代码
由于有个"\n",光标跑到下一行了,就是这样。   
作者: 大雄_重庆    时间: 2014-10-04 10:14
回复 6# zhaohongjian000

好的。明白了,真是谢谢你了!
   
作者: kaede_1    时间: 2014-10-08 11:16
回复 6# zhaohongjian000


    问一下,流程会走到,先输出父的print,在输出子的print吗?




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2