区分python中的进程与线程


Posted in Python onAugust 13, 2020

今天整理的文章是给大家梳理Python的进程与线程的区别,没什么代码,希望大家能清楚知道他们的区别,什么情况用线程,什么情况用进程做到心中有数,希望大家能熟练掌握.

进程的基本概念

概念

进程就是一个程序在一个数据集上的一次动态执行过程。进程一般由程序、数据集、进程控制块三部分组成。我们编写的程序用来描述进程要完成哪些功能以及如何完成;数据集则是程序在执行过程中所需要使用的资源;进程控制块用来记录进程的外部特征,描述进程的执行变化过程,系统可以利用它来控制和管理进程,它是系统感知进程存在的唯一标志。

线程的基本概念

概念

线程是进程中执行运算的最小单位,是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行。

好处

  • 易于调度。
  • 提高并发性,通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。
  • 开销少,创建线程比创建进程要快,所需开销很少

进程的基本状态及状态之间的关系

状态:运行、阻塞、挂起阻塞、就绪、挂起就绪

状态之间的转换:

  1. 准备就绪的进程,被CPU调度执行,变成运行态;
  2. 运行中的进程,进行I/O请求或者不能得到所请求的资源,变成阻塞态;
  3. 运行中的进程,进程执行完毕(或时间片已到),变成就绪态;
  4. 将阻塞态的进程挂起,变成挂起阻塞态,当导致进程阻塞的I/O操作在用户重启进程前完成(称之为唤醒),挂起阻塞态变成挂起就绪态,当用户在I/O操作结束之前重启进程,挂起阻塞态变成阻塞态;
  5. 将就绪(或运行)中的进程挂起,变成挂起就绪态,当该进程恢复之后,挂起就绪态变成就绪态;

进程和线程的关系:

  • 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
  • 资源分配给进程,同一进程的所有线程共享该进程的所有资源。
  • 处理机分给线程,即真正在处理机上运行的是线程
  • 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。线程是指进程内的一个执行单元,也是进程内的可调度实体.

进程与线程的区别:

  • 运行方式不同

进程不能单独执行,它只是资源的集合。
进程要操作CPU,必须要先创建一个线程。
所有在同一个进程里的线程,是同享同一块进程所占的内存空间。

  • 关系

进程中第一个线程是主线程,主线程可以创建其他线程;其他线程也可以创建线程;线程之间是平等的。
进程有父进程和子进程,独立的内存空间,唯一的标识符:pid。

  • 速度

启动线程比启动进程快
运行线程和运行进程速度上是一样的,没有可比性
线程共享内存空间,进程的内存是独立的。

  • 创建

父进程生成子进程,相当于复制一份内存空间,进程之间不能直接访问
创建新线程很简单,创建新进程需要对父进程进行一次复制
一个线程可以控制和操作同级线程里的其他线程,但是进程只能操作子进程。

  • 交互

同一个进程里的线程之间可以直接访问。
两个进程想通信必须通过一个中间代理来实现。

  • 调度

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

  • 并发性

不仅进程之间可以并发执行,同一个进程的多个线程之间也可并发执行

  • 拥有资源:

进程是拥有资源的一个独立单位,线程不拥有系统资源,但可以访问隶属于进程的资源.

  • 系统开销:

在创建或撤消进程时,由于系统都要为之分配和回收资源,导致系统的开销明显大于创建或撤消线程时的开销。

以上就是区分python中的进程与线程的详细内容,更多关于python进程与线程的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
Apr 15 Python
Python构造函数及解构函数介绍
Feb 26 Python
简单介绍Python中的struct模块
Apr 28 Python
详解Python中表达式i += x与i = i + x是否等价
Feb 08 Python
pandas创建新Dataframe并添加多行的实例
Apr 08 Python
Python用5行代码写一个自定义简单二维码
Oct 21 Python
详解pyenv下使用python matplotlib模块的问题解决
Nov 29 Python
简单了解django缓存方式及配置
Jul 19 Python
python pygame实现球球大作战
Nov 25 Python
Python程序控制语句用法实例分析
Jan 14 Python
Python如何实现小程序 无限求和平均
Feb 18 Python
Python使用paramiko连接远程服务器执行Shell命令的实现
Mar 04 Python
python判断一个变量是否已经设置的方法
Aug 13 #Python
vscode+PyQt5安装详解步骤
Aug 12 #Python
python使用列表的最佳方案
Aug 12 #Python
Python实现播放和录制声音的功能
Aug 12 #Python
Python实现文件压缩和解压的示例代码
Aug 12 #Python
Python爬取数据并实现可视化代码解析
Aug 12 #Python
Python下载网易云歌单歌曲的示例代码
Aug 12 #Python
You might like
PHP循环获取GET和POST值的代码
2008/04/09 PHP
php实现的在线人员函数库
2008/04/09 PHP
PHP+MySQL 手工注入语句大全 推荐
2009/10/30 PHP
PHP+Ajax异步通讯实现用户名邮箱验证是否已注册( 2种方法实现)
2011/12/28 PHP
PHP 断点续传实例详解
2017/11/11 PHP
Yii2.0实现的批量更新及批量插入功能示例
2019/01/29 PHP
js函数调用常用方法详解
2012/12/03 Javascript
document.createElement()用法
2013/03/13 Javascript
jQuery实现密保互斥问题解决方案
2013/08/16 Javascript
使用Jquery实现点击文字后变成文本框且可修改
2013/09/21 Javascript
Javascript保存网页为图片借助于html2canvas库实现
2014/09/05 Javascript
jquery中live()方法和bind()方法区别分析
2016/06/23 Javascript
JS实现放大、缩小及拖拽图片的方法【可兼容IE、火狐】
2016/08/23 Javascript
loading动画特效小结
2017/01/22 Javascript
Bootstrap模态窗口源码解析
2017/02/08 Javascript
Form表单上传文件(type="file")的使用
2017/08/03 Javascript
JS实现Cookie读、写、删除操作工具类示例
2018/08/28 Javascript
实用Javascript调试技巧分享(小结)
2019/06/18 Javascript
JavaScript 绘制饼图的示例
2021/02/19 Javascript
[03:55]2014DOTA2国际邀请赛 Fnatic经理采访赢DK在情理之中
2014/07/10 DOTA
python 不关闭控制台的实现方法
2011/10/23 Python
python中readline判断文件读取结束的方法
2014/11/08 Python
Python的Django框架中URLconf相关的一些技巧整理
2015/07/18 Python
[原创]pip和pygal的安装实例教程
2017/12/07 Python
python中嵌套函数的实操步骤
2019/02/27 Python
django的分页器Paginator 从django中导入类
2019/07/25 Python
Python+Selenium+phantomjs实现网页模拟登录和截图功能(windows环境)
2019/12/11 Python
Django实现whoosh搜索引擎使用jieba分词
2020/04/08 Python
公司授权委托书
2014/04/04 职场文书
买房协议书
2014/04/11 职场文书
2014年乡镇纪委工作总结
2014/12/19 职场文书
婚礼答谢词
2015/01/04 职场文书
MySQL infobright的安装步骤
2021/04/07 MySQL
关于PHP数组迭代器的使用方法实例
2021/11/17 PHP
一文简单了解MySQL前缀索引
2022/04/03 MySQL
Docker部署Mysql8的实现步骤
2022/07/07 Servers