进程和线程的区别和联系?什么时候应该用进程?什么时候用线程?

作者: veaxen 分类: 笔试面试 发布时间: 2017-07-22 16:44

线程进程的区别体现在3个方面

第一:因为进程拥有独立的堆栈空间和数据段,所以每当启动一个新的进程必须分配给它独立的地址空间,建立众多的数据表来维护它的代码段、堆栈段和数据段,这对于多进程来说十分“奢侈”,系统开销比较大,而线程不一样,线程拥有独立的堆栈空间,但是共享数据段,它们彼此之间使用相同的地址空间,共享大部分数据,比进程更节俭,开销比较小,切换速度也比进程快,效率高,但是正由于进程之间独立的特点,使得进程安全性比较高,也因为进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。一个线程死掉就等于整个进程死掉。

第二:体现在通信机制上面,正因为进程之间互不干扰,相互独立,进程的通信机制相对很复杂,譬如管道,信号,消息队列,共享内存,套接字等通信机制,而线程由于共享数据段所以通信机制很方便。

第三:体现在CPU系统上面,线程是CPU执行的基本单位,线程使得CPU系统更加有效,因为操作系统会保证当线程数不大于CPU数目时,不同的线程运行于不同的CPU上。

进程与线程的联系

我们知道,当我们一个进程中有多线程时,如果我们在其中一个线程中执行fork函数,创建一个新进程时,那么子进程将拥有和父进程一样的内存,子进程继承了父进程的关于多线程的相关同步和互斥机制相关的数据,但是需要注意的是,子进程并不会像父进程一样是多线程的,子进程只包含执行了fork函数的线程,父进程所有关于多线程的数据都被子进程继承了下来,但是子进程已经不是多线程的了,这在多线程、多进程编程应该注意到。但是一般情况下,我们不会在一个程序中即采用多线程同时又采用多进程的编程方式。

进程与线程的选择

进程与线程的选择取决以下几点:
1、需要频繁创建销毁的优先使用线程;因为对进程来说创建和销毁一个进程代价是很大的;
2、线程的切换速度快,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应;
3、因为对CPU系统的效率使用上线程更占优,所以可能要发展到多机分布的用进程,多核分布用线程;
4、并行操作时使用线程,如C/S架构的服务器端并发线程响应用户的请求;
5、需要更稳定安全时,适合选择进程;需要速度时,选择线程更好。

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!

一条评论

发表评论

电子邮件地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据