进程,线程以及多线程,多进程
进程是指在系统中正在运行的一个利用程序;程序一旦运行就是进程,还是更专业化来讲:进程是指程序履行时的一个实例,线程是进程的一个实体。
进程——资源分配的最小单位,线程——程序履行的最小单位。
线程进程的区分体现在因素有哪些:
0:由于进程具有独立的堆栈空间和数据段,所以每当启动一个新的进程一定要分配给它独立的地址空间,建立众多的数据表来保护它的代码段、堆栈段和数据段,这对多进程来讲十分“奢侈”,系统开消比较大,而线程不一样,线程具有独立的堆栈空间,但是同享数据段,它们彼此之间使用相同的地址空间,同享大部份数据,比进程更节俭,开消比较小,切换速度也比进程快,效力高,但是正由于进程之间独立的特点,使得进程安全性比较高,也由于进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同履行路径。一个线程死掉就等于全部进程死掉。
1:体现在通讯机制上面,正由于进程之间互不干扰,相互独立,进程的通讯机制相对很复杂,比方管道,信号,消息队列,同享内存,套接字等通讯机制,而线程由于同享数据段所以通讯机制很方便。
2:属于同一个进程的所有线程同享该进程的所有资源,包括文件描写符。而不同的进程相互独立。
3:线程又称为轻量级进程,进程有进程控制块,线程有线程控制块;
4:线程一定也只能属于一个进程,而进程可以具有多个线程而且最少具有一个线程;
5:体现在程序结构上,举一个简明易懂的列子:当我们使用进程的时候,我们不自主的使用ifelse嵌套来判断pid,使得程序结构繁琐,但是当我们使用线程的时候,基本上可以甩掉它,固然程序内部履行功能单元需要使用的时候或要使用,所以线程对程序结构的改良有很大帮助。
进程与线程的选择取决以下几点:
0:需要频繁创建烧毁的优先使用线程;由于对进程来讲创建和烧毁一个进程代价是很大的。
1:线程的切换速度不错,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高利用程序的响应
2:由于对CPU系统的效力使用上线程更占优,所以可能要发展到多机散布的用进程,多核散布用线程;
3:并行操作时使用线程,如C/S的服务器端并发线程响利用户的要求;
4:需要更稳定安全时,合适选择进程;需要速度时,选择线程更好。