您的位置:首页 > 运维架构 > Linux

linux下fork和pthread混用的问题

2014-04-03 16:33 211 查看
linux下编程处理并行任务时,可以采用多进程模块(fork)或者多线程模型(pthread)。有时候还会采用混合的模式。

当混合使用两者的时候,可能存在一些问题。

 

一种情况是:

进程创建了一些线程,然后执行了fork。代码编写者的意图可能是希望fork出很多个副本,执行同样的任务。可是fork之前创建的线程却并没有被复制,只有最初的进程拥有该线程。

 

另一种情况是:

进程创建了一些线程用于处理一些工作。然后希望转到后台运行,于是调用了daemon函数。这时,发现进程确实转到后台了。但是开始创建的线程却莫名其妙地退出了。原因和上面是一样的。daemon函数也是通过fork出子进程并退出父进程实现的。fork出来的子进程并没有父进程在fork之前创建的线程。而这些线程则随父进程退出而一起被销毁了。

 

因此,在使用daemon函数或者fork的时候,如果要创建线程,一定要在他们之后创建。父进程应该只做简单的初始化工作。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: