进程-----资源分配的最小单位,线程-----程序执行的最小单位
进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位
两者之间的区别体现在以下方面:
- 因为进程拥有独立的堆栈空间和数据段,所以每当启动一个新的进程必须给分配给它独立的地址空间,建立众多的数据表来维护它的代码段,堆栈段和数据段,这对多进程来说十分“奢侈”,系统相对来说开销就比较大,而线程不一样,线程具有独立的堆栈空间,但是共享数据段,他们彼此之间使用相同的地址空间,共享大部分数据,比进程更节俭,开销比较小,切换速度也比进程快,效率高,但是正由于进程之间独立的特点,使得进程安全性比较高,也因为进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其他进程产生影响,而线程只是一个进程中不同的执行路径,一个线程死掉就等于整个进程死掉。
- 通信机制上,进程之间互不干扰,相互独立,通信机制相对很复杂,比如管道,消息队列,信号,功效内存,套接字等通信机制,而线程由于共享数据段所以通信机制很方便。
- 属于同一个进程的所有线程共享该进程的所有资源,包括文件描述符。
- 线程必定也只能属于一个进程,而进程可以拥有多个线程而且至少拥有一个线程。
进程和线程的选取:
- 需要频繁创建销毁的优先使用线程,因为对进程来说创建和销毁一个简称代价是很大的
- 线程的切换速度快,所以需要大量计算,切换频繁是用线程,还有耗时的操作使用线程可挺高应用程度的响应。
- 因为对CPU系统的效率使用上线程各要占优,所以可能要发展到多机的用进程,多核分布用线程。
- 并行操作时使用线程,比如cs架构的服务器端并发现货层响应用户的请求。
- 需要稳定安全时,适合选择进程,需要速度时,选择线程更好。