线程和进程

来源:互联网 发布:linux磁盘配额 编辑:程序博客网 时间:2024/06/07 11:50
什么情况下需要创建线程?

我不大清楚什么时候需要创建线程?什么时候需要创建进程? 


首先要了解线程,进程的概念。
进程,是一个可执行程序的一次运行。
线程,是一个可执行程序的一条运行路径。
一个进程,可以同时有许多线程运行。


程序可以写一些代码,开一个线程执行。
但是开进程就不是那么简单了。

只能写一个程序,编译后供其他程序调用。

不过Unix ,linux 的进程和线程的界限很模糊。
在这种操作系统中,线程只是一个轻量级的进程。

线程没有独立的内存空间,进程有自己的独立空间。
进程是操作系统分配资源的单位,线程不是,线程只是独立运行的一段代码。

程序员对线程,有更多的控制权;
一个进程里面的所有线程,代码都是程序员编写的;
线程之间如何协调工作,都是程序员可以控制的。

对进程,操作系统可以控制的更多,而程序员能够控制的很少。
进程是线程的容器。

多进程,每一个进程,都需要一份资源,多线程,可以共享这些资源。



下面是一个对fork的笔试题加解释,分享一下。

#include <unistd.h>  #include <stdio.h>     int main()  {          fork();/*****/             fork() && fork() || fork();/*****/             fork();/*****/             sleep(100);             return 0;  }  

问题是不算main这个进程自身,程序到底创建了多少个进程?


这是EMC的一道笔试题,感觉挺有意思的,这道题主要考了两个知识点,一是逻辑运算符运行的特点;二是对fork的理解


如果有一个这样的表达式:cond1 && cond2 || cond3 这句代码会怎样执行呢?


1、cond1为假,那就不判断cond2了,接着判断cond3
2、cond1为真,这又要分为两种情况:
  a、cond2为真,这就不需要判断cond3了
  b、cond2为假,那还得判断cond3


fork调用的一个奇妙之处在于它仅仅被调用一次,却能够返回两次,它可能有三种不同的返回值:
1、在父进程中,fork返回新创建子进程的进程ID;
2、在子进程中,fork返回0;
3、如果出现错误,fork返回一个负值(题干中说明了不用考虑这种情况)


在fork函数执行完毕后,如果创建新进程成功,则出现两个进程,一个是子进程,一个是父进程。在子进程中,fork函数返回0,在父进程中,fork返回新创建子进程的进程ID。我们可以通过fork返回的值来判断当前进程是子进程还是父进程。


有了上面的知识之后,下面我们来分析fork() && fork() || fork()会创建几个新进程


很明显fork() && fork() || fork()创建了4个新进程

总结:

第一注释行的fork生成1个新进程
第二注释行的三个fork生成4+4=8个新进程
第三注释行的fork会生成10个新进程(这是因为前面总共有10个进程,调用一次fork生成10个新进程)

所以一共会生成1+8+10=19个新进程


0 0