浅谈进程,线程以及多线程,多进程的选择

网络 通信技术
我的理解是进程是指在系统中正在运行的一个应用程序;程序一旦运行就是进程,或者更专业化来说:进程是指程序执行时的一个实例,线程是进程的一个实体。

我的理解是进程是指在系统中正在运行的一个应用程序;程序一旦运行就是进程,或者更专业化来说:进程是指程序执行时的一个实例,线程是进程的一个实体。

进程——资源分配的最小单位,线程——程序执行的最小单位。

[[258231]]

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

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

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

2:属于同一个进程的所有线程共享该进程的所有资源,包括文件描述符。而不同的进程相互独立。

3:线程又称为轻量级进程,进程有进程控制块,线程有线程控制块;

4:线程必定也只能属于一个进程,而进程可以拥有多个线程而且至少拥有一个线程;

5:体现在程序结构上,举一个简明易懂的列子:当我们使用进程的时候,我们不自主的使用if else嵌套来判断pid,使得程序结构繁琐,但是当我们使用线程的时候,基本上可以甩掉它,当然程序内部执行功能单元需要使用的时候还是要使用,所以线程对程序结构的改善有很大帮助。 

进程与线程的选择取决以下几点:

0:需要频繁创建销毁的优先使用线程;因为对进程来说创建和销毁一个进程代价是很大的。

1:线程的切换速度快,所以在需要大量计算,切换频繁时用线程,还有耗时的操作使用线程可提高应用程序的响应

2:因为对CPU系统的效率使用上线程更占优,所以可能要发展到多机分布的用进程,多核分布用线程;

3:并行操作时使用线程,如C/S 的服务器端并发线程响应用户的请求;

4:需要更稳定安全时,适合选择进程;需要速度时,选择线程更好。

责任编辑:武晓燕 来源: 今日头条
相关推荐

2022-03-09 17:01:32

Python多线程多进程

2023-12-13 09:56:13

​多进程多线程协程

2021-06-11 11:28:22

多线程fork单线程

2020-04-07 11:10:30

Python数据线程

2021-04-20 12:39:52

Node.js多线程多进程

2021-09-10 21:25:43

Redis分布式

2021-08-04 23:30:28

Node.js开发线程

2010-07-26 09:45:09

Perl多进程

2016-10-09 20:15:30

多线程多进程

2021-06-11 06:54:35

PythonThreadingMultiproces

2019-06-03 09:13:11

线程进程多线程

2023-12-11 18:18:24

Python编程线程

2013-12-02 17:33:20

Linux进程多线程

2022-05-26 08:31:41

线程Java线程与进程

2023-11-01 11:20:57

2022-01-04 09:53:37

Python多线程多进程

2023-11-28 13:52:00

Python多进程多线程

2023-05-10 07:47:08

Python并发编程

2009-10-28 10:01:57

2012-06-20 14:07:28

多线程架构单线程
点赞
收藏

51CTO技术栈公众号