进程就是程序的一次执行活动,是系统进行资源分配和调度的一个独立单位,程序是静态的,进程是动态的。 而引入线程的目的,我认为主要有以下四个优点: (1)易于调度。 (2)提高并发性。通过线程可以方便有效地实现并发。 (3)开销小。 (4)有利于发挥多处理器的功能。通过创建多线程,每个线程都在一个处理器上运行,从而实现应用程序的并行,使每个处理器得到充分运行。
线程和进程的区别: (1)一个线程必定属于也只能属于一个进程,而一个进程可以拥有多个线程并且至少拥有一个线程。 (2)属于一个进程的所有线程共享该进程的所有资源,包括打开的文件,创建的socket等。不同的进程相互独立。 (3)线程又称为轻量级进程。进程有进程控制块,线程也有线程控制块。但线程控制块比进程控制块小得多。线程之间切换小,进程间切换代价大。 (4)进程是程序的一次执行,线程可以理解为程序段中的一段程序片段的执行。 (5)每个进程都有独立的内存空间,而线程共享其所属进程的内存空间。
多进程和多线程的区别: 多进程数据是分开的,共享复杂,需要用IPC,同步简单 多线程共享进程数据,共享简单,同步复杂
多进程占用内存多,切换复杂,cpu利用率低 多线程占用内存少,切换简单,cpu利用率高
多进程创建销毁切换复杂,速度慢 多线程创建销毁简单,速度快
多进程编程简单,调试简单 多线程编程复杂,调试复杂
可靠性: 多进程间不会互相影响 一个线程挂掉将导致整个进程挂掉
分布式: 多进程适应于多核,多机分布,如果一台机器不够,扩展到多台机器比较简单 多线程适应于多核分布
总的来说,多进程的优点是内存隔离,单个进程的异常不会导致整个应用的崩溃,方便调试。缺点是进程间调用,通讯和切换开销均比多线程大,使用场合适合目标子功能间交互少,如果资源和性能许可,设计由多个子应用程序来组合完成目标(网上看到这句话,还有待于理解)
多线程的优点是提高系统的并行性,并且开销小,缺点是没有内存隔离,单个线程的崩溃会导致整个应用的退出,发生内存等bug时,定位极其不方便。使用场合:适合于存在大量IO,网络等耗时操作或者需要和用户交互时,使用多线程有利于提高系统的并行性和用户界面快速响应从而提高友好性。
所以需要频繁创建销毁的优先使用线程,如web服务器,需要进行大量计算的优先使用线程 强相关的处理使用线程,弱相关的处理使用进程。