点击上方 "程序员小乐"关注, 星标或置顶一起成长
每天凌晨00点00分, 第一时间与你相约
每日英文
The moment you think about giving up,think of the reason why you held on so long.
每当你想放弃的时候,想一想是什么支撑着你一路坚持。
每日掏心话
你不知道,我的心情一直被你左右。有时候,躲避是为了让自己不那么失望。
来自:For_zwb | 责编:乐乐
链接:blog.csdn.net/weixin_42250655/article/details/81567643
孤儿进程
孤儿字面意思就是没有父母的孩子,那孤儿进程的意思就是没有父进程的进程。这种情况是怎么发生的呢?就是父进程先于子进程结束,这时子进程被init进程收养,init的进程号为1。
僵尸进程
当一个子进程终止时,如果它的父进程还在运行,内核会为这个终止的子进程保留一定量的信息。父进程可以根据这些信息知道子进程的情况。直到父进程对其进行了善后处理,子进程才会完全终止。在这期间,父进程没有回收子进程并释放子进程占用的资源,这个子进程会成为僵尸进程,它仍然占用一定资源。
进程终止
①从main函数返回 return()。
②调用 exit()。
③调用 _exit()或 _Exit()。
④最后一个线程从其启动例程返回。
⑤最后一个线程调用 pthread_exit()。
⑥调用 abort()它产生 SIGABRT 信号。
⑦收到一个信号并终止。
⑧最后一个线程对取消请求作出相应。
进程组
每个进程都属于某个进程组。进程组是一个或多个进程的集合。通常它们与同一作业相关联,可以接收来自同一终端的各种信号。每个进程组有一个唯一的进程组ID。每个进程组都有一个组长进程,进程ID等于进程组ID的进程就是组长进程。
会话
会话(session)是一个或多个进程组的集合。
竞态条件
当多个进程都企图对共享数据进行某种处理时,而最后的结果又取决于进程运行的顺序时,我们认为发生了竞态条件(race condition)。如果fork之后的某种逻辑显式或隐式地依赖于在fork之后是父进程先运行还是子进程先运行,那么fork函数就会是竞争条件活跃的滋生地。通常,我们都是不可以预估子进程和父进程哪个先运行。因为进程的运行顺序完全取决于内核的调度算法和系统的负载。
我们可以调用wait或者waitpid函数来让父进程等待子进程运行完之后在运行,这样父进程就会被阻塞住,直到子进程运行完毕之后才能运行,其实这样做的效率就比较低,我们fork就是希望多进程并发的执行,如果采用此方法,则fork也就失去了很大的意义。
为了避免竞争条件和不采用wait或waitpid方法,我们可以在多进程之间采用发送和接收信号的处理方法来避免竞态条件。或者各种进程间的通信方式(IPC)也可以使用。
欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,学习能力的提升上有新的认识,欢迎转发分享给更多人。
猜你还想看
阿里、腾讯、百度、华为、京东最新面试题汇集
用 Java 实现梯度下降,看这篇就对了!
各种 Java Web 开发人员的通用工具
Git 如何优雅地回退代码,用 reset 还是 revert ?
关注订阅号「程序员小乐」,收看更多精彩内容嘿,你在看吗?
,