什么时候用进程,什么时候用线程
线程进程的区别体现在几个方面:
- 地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
- 通信: 进程间通信 IPC(管道,信号量,共享内存,消息队列,信号,套接字),线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
- 调度和切换:线程上下文切换比进程上下文切换要快得多。
- 在多线程OS中,进程不是一个可执行的实体。
进程与线程的选择取决以下几点:
- 需要频繁创建销毁的优先使用线程;因为对进程来说创建和销毁一个进程代价是很大的。
- 线程的切换速度快,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应
- 因为对CPU系统的效率使用上线程更占优,所以可能要发展到多机分布的用进程,多核分布用线程;
- 并行操作时使用线程,如C/S架构的服务器端并发线程响应用户的请求;
- 需要更稳定安全时,适合选择进程;需要速度时,选择线程更好。
本文探讨了进程和线程的区别,包括资源分配、通信方式、调度和切换效率。指出在需要频繁创建销毁、快速响应、多核计算和并行操作时,线程是更好的选择;而对CPU效率和稳定性的要求,则倾向于使用进程。选择依据包括任务的创建销毁频率、计算密集程度和系统资源利用。
1018

被折叠的 条评论
为什么被折叠?



