进程和线程的定义和区别

进程和线程的定义和区别

1、进程定义

进程:是具有一定独立功能的程序关于某个数据集合上的一次进行活动,是系统进行资源分配和调度的一个独立单位。

 

2、线程定义

线程:是进程的一个实体,是cpu调度和分派的基本单位,他是比进程更小的能够独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源。一个线程可以创建和撤销拎一个线程。

 

区别:

1、一个线程只能属于一个进程,而一个进程可以拥有多个线程。

2、线程是进程工作的最新单位。

3、一个进程会分配一个地址空间,进程与进程之间不共享地址空间。即不共享内存。

4、同一个进行下的不同的多个线程,共享父进程的地址空间。

5、线程在执行过程中,需要协助同步。不同进程的线程间要利用消息通信的办法实现同步。

6、线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。

 

进程的优点:

1、每个进程互相独立,不影响主程序的稳定性,子进程崩溃不影响其他进程。

2、通过增加CPU,就可以扩充性能。

3、可以尽量减少线程加锁与解锁的影响,极大的提高了性能。

 

进程的缺点:

1、逻辑控制复杂,需要和主程序交互。

2、多进程调度开销大。

 

线程的优点:

1、程序逻辑和控制方式简单。

2、所有线程可以直接共享内存和变量等。

3、线程方式消耗的总资源比进程方式少。

 

线程的缺点:

1、每个线程和主程序共用地址空间,最大内存地址受限。

2、线程之间的同步和加锁不易控制。

3、一个线程的崩溃可能影响到整个程序的稳定性。

 

 

•进程(process):
狭义定义:进程就是一段程序的执行过程。
广义定义:进程是一个具有独立功能的程序关于某个数据集合的一次运行活动。他是操作系统动态执行的基本单元,在传统的操作系统中,进程即是基本的分配单元,也是基本的执行单元。

1)进程是一个实体,每个进程都有自己的地址空间,一般情况下,包含文本区域、数据区域、堆栈
2)进程是执行中的程序,程序是一个没有生命的实体,只有处理器赋予程序生命时,他才能成为一个活动的实体,我们称之为进程
3)进程本身不会运行,是线程的容器。线程不能单独执行,必须组成进程
4)一个程序至少有一个进程,一个进程至少有一个线程
5)对于操作系统来讲,一个任务就是一个进程,比如打开一个浏览器就是启动一个浏览器进程。打开一个记事本就是启动一个记事本进程,打开2个记事本就是启动2个记事本进程
6)有些进程还不止同时做一件事情。比如打开word,他可以同时进行打字、打印、拼音检查等等,在一个进程内部,要同时干多件事情。


进程状态:
1)就绪:获取出CPU外的所有资源、只要处理器分配资源就可以马上执行
2)运行:获得处理器分配的资源,程序开始执行
3)阻塞:当程序条件不够的时候,需要等待提交满足的时候才能执行。



•线程:
1)一个进程中至少有一个线程,不然就没有存在的意义
2)在一个进程内部,要同时干多件事情,就需要同时运行多个子任务,我们把进程内的这些子任务叫做线程
3)多线程就是为了同步完成多项任务(在单个程序中同时运行多个线程完成不同的任务和工作),不是为了提高运行效率,而是为了提高资源使用效率来提高系统的效率
4)一个简单的比喻,多线程就像是火车上的每节车厢,而进程就是火车
5)线程是程序执行流的最小单元。一个标准的线程由当前的线程ID、当前指令指针、寄存器和堆栈组成
6)同一个进程中的多个线程之间可以并发执行


线程状态:
1)就绪:指线程具备运行的所有条件,逻辑上可以运行,在等待处理机
2)运行:指线程占用处理机正在运行
3)阻塞:线程在等待一个事件,逻辑上不可执行


如果我们要同时执行多个任务怎么办?
1)启动多个进程,每个进程虽然只有一个线程,但是多个进程可以一块执行多个任务
2)启动一个进程,在一个进程内启动多个线程,这样多个线程也可以一块执行多个任务


多任务:
1)一边浏览网页、一边听歌、一边看电影;这就是多任务。

转载于:https://www.cnblogs.com/liliuguang/p/10616083.html

### 进程线程定义 #### 进程 进程是并发执行的程序在执行过程中分配管理资源的基本单位,是一个动态的概念,也是竞争计算机系统资源的基本单位。进程具有独立性、异步性结构特征,在多道程序环境下,允许多个进程并发执行[^2]。 #### 线程 线程进程中执行运算的最小单元,是操作系统执行处理机制的基本单位。每个进程至少包含一个线程线程能够利用所属进程所拥有的资源来完成特定的任务。相比于进程而言,线程作为更小的独立运行基本单位,也被称作轻量级进程[^1]。 ### 进程线程区别 #### 资源开销方面 创建一个新的进程需要为其分配内存空间其他资源,因此创建新进程的成本较高;而创建新的线程只需要少量额外的数据结构即可实现,所以成本较低。由于线程共享同一进程内的大部分数据代码段,这使得线程间的通信变得简单快捷[^3]。 #### 执行效率方面 当应用程序中有大量相似任务需同时进行时,采用多线程技术可显著提高CPU利用率以及整体性能表现。因为切换不同线程所需时间较短,所以在频繁上下文转换场景下优势明显。然而对于跨进程间协作,则涉及到更为复杂的IPC (Inter-Process Communication) 机制。 #### 隔离保护程度上 各个进程之间相互隔离良好,各自享有私有地址空间,除非通过专门设计好的接口方式交互外无法直接访问对方内部信息。相反地,同属一进程下的所有线程则共同占有该进程范围内的全部资源,这意味着如果某个线程出现了错误可能会波及其他正常工作的部分。 ```python import threading def print_numbers(): for i in range(5): print(f'Number {i}') thread = threading.Thread(target=print_numbers) thread.start() thread.join() print('Finished printing numbers.') ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值