位置: IT常识 - 正文

python的多线程(python的多线程 吃cpu太厉害)

编辑:rootadmin
一、线程的概念线程是CPU分配资源的基本单位。当一程序开始运行,这个程序就变成了一个进程,而一个进程相当于一个或者多个线程。当没有多线程编程时,一个进程相当于一个主线程;当有多线程编程时,一个进程包含多个线程(含主线程)。使用线程可以实现程序大的开发。 多个线程可以在同一个程序中运行,并且每一个线程 ...

推荐整理分享python的多线程(python的多线程 吃cpu太厉害),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:python的多线程模块,python的多线程写聊天软件,python的多线程能否用来做并行计算,python的多线程机制,python的多线程模块,python的多线程和java的多线程,python的多线程机制,python的多线程机制,内容如对您有帮助,希望把文章链接给更多的朋友!

一、线程的概念线程是CPU分配资源的基本单位。当一程序开始运行,这个程序就变成了一个进程,而一个进程相当于一个或者多个线程。当没有多线程编程时,一个进程相当于一个主线程;当有多线程编程时,一个进程包含多个线程(含主线程)。使用线程可以实现程序大的开发。

多个线程可以在同一个程序中运行,并且每一个线程完成不同的任务。

多线程实现后台服务程序可以同时处理多个任务,并不发生阻塞现象。

多线程的程序设计的特点就是能够提高程序执行效率和处理速度。python程序可以同时并行运行多个相对独立的线程。

二、创建多线程python支持两种创建多线程的方式:

~通过 threading.Thread () 创建。

~通过继承 threading.Thread 类的继承。

1.通过 threading.Thread () 创建

语法形式:

thread.Thread(group=Nore,targt=None,args=(),kwargs={},*,daemon=None)

参数解释:

~group:必须为None,于ThreadGroup类相关,一般不使用。

~target:线程调用的对象,就是目标函数。

~name:为线程起这个名字。默认是Tread-x,x是序号,由1开始,第一个创建的线程名字就是Tread-1。

~args:为目标函数传递关键字参数,字典。

~daemon:用来设置线程是否随主线程退出而退出。

示例:

import threadingdef test (x,y): for i in range(x,y): print(i)thread1 = threading.Thread(name='t1',target= test,args=(1,10))thread2 = threading.Thread(name='t2',target= test,args=(11,20))thread1.start() #启动线程1thread2.start() #启动线程2123456789111213141516171819

解释:两个程序会并发运行,所以结果不一定每次都是顺序的1~10,这是根据CPU给两个线程风马分配的时间片段来决定。可以看到每次结果都不同。

2.通过继承 threading.Thread 类的继承

threading.Thread是一个类,可以继承它。

示例:

import threadingclass mythread(threading.Thread): def run(self): for i in range(1,10): print(i)thread1 = mythread();thread2 = mythread();thread1.start()thread2.start()

输出:

123456789123456789

解释:自定义一个类继承threading.Thread,然后重写父类的run方法,线程启动时(执行start())会自动执行该方法。

三、主线程

在python中,主线程是第一个启动的线程。

~父线程:如果启动线程A中启动了一个线程B,A就是B的父线程。

~子线程:B就是A的子线程。

python的多线程(python的多线程 吃cpu太厉害)

创建线程时有一个damon属性,用它来判断主线程。当daemon设置False时,线程不会随主线程退出而退出,主线程会一直等着子线程执行完;。当daemon设置True时,线程会随主线程退出而退出,主线程结束其他的子线程会强制退出。

使用daemon注意:

~daemon属性必须在start( )之前设置,否则会引发RuntimeError异常

~每个线程都由daemon属性,可以显示设置也可以不设置,不设置则取默认值None

~如果子子线程不设置daemon属性,就取当前线程的daemon来设置它。子子线程继承子线程的daemon值,作用和设置None一样。

~从主线程创建的所有线程不设置daemon属性,则默认都是daemon=False。

示例:

import timeimport threadingdef test(): time.sleep(10) for i in range(10): print(i)thread1 = threading.Thread(target=test,daemon=False)thread1.start()print('主线程完成了')

输出:

主线程完成了123456789

解释:当主线程运行完毕输出完之后,等待一下后输出0~9。如果将daemon=False该为daemon=True,则不会运行for i in range(10)语句。

四、阻塞线程

一个线程中调用另一个线程的join方法,调用者被阻塞,直到调用线程被终止。

语法形式:

join(timeout-=None)

timeout 参数指定调用者等待多久,没有设置时,就一直等待被调用线程结束被调用线程结束。其中,一个线程可以被join多次调用。

示例:

import timeimport threadingdef test(): time.sleep(5) for i in range(10): print(i)thread1=threading.Thread(target=test)thread1.start()thread1.join()print('主线程完成了')

输出:

0123456789主线程完成了

解释:在thread1.start()后加thread1.join()添加join方法,输出时,主线程就会等待输出完0~9后再执行自己的print输出。

五、判断线程是否活动的

~run():用以表示线程活动的方法

~start():启动线程

~join():等待至线程终止

~isAlive():返回线程是否活动的

~getName():返回线程名称

~setName() : 设置线程名称

示例:

from threading import Thread, Eventimport timedef countdown(n, started_evt): print('正在运行') started_evt.set() while n > 0: print('时间', n) n -= 1 time.sleep(2)started_evt = Event()print('开始倒计时')t = Thread(target=countdown, args=(10, started_evt))t.start()started_evt.wait()print('倒计时运行')

输出:

开始倒计时正在运行时间 10倒计时运行时间 9时间 8时间 7时间 6时间 5时间 4时间 3时间 2时间 1

Alive,顾名思义,它表示线程当前是否为可用状态,如果线程已经启动,并且当前没有任何异常的话,则返回true,否则为false

Thread.isAlive() :顾名思义,是表示当前线程时候为可用状态,即是否已经在启动,并且在运行的状态;

六、线程同步1.同步概念

异步模式的情况下,同时有一个线程在修改共享数据,另一个线程在读取共享数据,当修改的共享数据的线程没有处理完毕,读取数据的线程肯定会得到错误的结果。如果采用多线程的同步控制机制,当处理共享数据的线程完成处理数据之后,读取线程就读取数据。

python的锁就解决这一问题,锁住线程,只允许一个线程操作,其他线程排队等待,待当前线程操作完毕后,再按顺序一个一个来运行。

2. python的锁

python的threading模块提供了RLock锁解决方法。在某一时间只能让一个线程操作的语句放到RLock的acquire方法和release方法之间,即acquire相当于给RLack上锁,而release相当于解锁。

示例:

import threadingclass mythread(threading.Thread): def run(self): global x #
本文链接地址:https://www.jiuchutong.com/zhishi/310220.html 转载请保留说明!

上一篇:WordPress如何批量删除无用的标签(wordpress批量生成文章)

下一篇:java中TimerTask是什么(java timestamp localdatetime)

  • 房地产企业样板房会计处理
  • 委托加工业务的会计处理
  • 消费税的计算方法有哪三种
  • 中国注册税务师报考条件
  • 公司的个人所得税是多少
  • 零余额账户出纳做什么
  • 未休年假补助
  • 指定扣缴和法定扣缴区别
  • 增值税计入当期损益吗?
  • 境外企业所得税税率
  • 融资担保公司会计建议有哪些要求
  • 政府补贴项目账务怎么做
  • 年报所得税与季报的区别
  • 单位起诉员工赔偿算劳动争议
  • 公司是否可以开电子发票
  • 增值税只有销项没有进项怎么做账
  • 劳务发票需要身份证原件吗
  • 只开增值税普通发票,需要申报税务吗
  • 服务行业也有合伙人吗
  • 劳务派遣企业如何认定
  • 自然人出租房屋增值税税率
  • 增值税核算应设置的会计科目排序
  • 期交保费资金占用年限计算公式
  • 施工企业工作流程
  • 外地职工医保怎么报销
  • 企业原材料盘盈的原因分析
  • 劳务成本属于费用项目吗
  • 企业季度所得税可以弥补以前年度亏损吗
  • win10禁用安全杀毒功能
  • 结转净利润到利润分配
  • php socket函数
  • Win11如何关闭屏保上的广告
  • 不符合win11硬件要求安装会怎么样
  • 支付手续费委托代销是什么意思
  • 蕾德纳斯
  • php调试工具哪个好用
  • php微信公众号开发框架
  • 模糊数学神经网络
  • php常用时间函数
  • lvs命令
  • 账面未分配利润等于净利润?
  • python方差齐性检验
  • 人力资源服务的发票明细
  • 电子承兑被退回要重新背书怎么办
  • 营改增后建筑企业财务核算
  • sql server 自定义排序
  • 个人提供的劳务费要开发票,但是薪资不需要开发票
  • 金蝶新建账套如何录入固定资产账套
  • 金税四期的主要功能
  • 小规模纳税人出售使用过固定资产
  • 工程外经证预缴税款计税方法
  • 不抵扣进项税额转出怎么做分录处理
  • 企业固定资产可以不提折旧吗
  • 周转材料期末余额怎么算
  • 小规模公司怎样添加员工
  • 盈余公积的会计分录
  • 有借必有贷借贷必相等的记账规则适用于
  • 关于低值易耗品的评估说法正确的有()
  • 股东向公司借款协议
  • 银行承兑汇票托收凭证
  • 并购成本计算公式
  • 股权变更需要多久
  • system表空间满了怎么处理
  • ubuntu安装软件教程
  • win7怎么用耳机听歌
  • ubuntu20.04怎么用
  • Win7系统如何开启移动到文件夹选项
  • jquery.ui
  • 铁嘴银牙剧情简介
  • JavaScript数据类型分为哪两大类
  • 批处理界面
  • incaseformat查杀
  • settimeout和setinterval在安卓机无效
  • jquery easyui插件
  • python爬虫快速入门
  • 按犍设置
  • 河北省国家税务局电子税务局
  • 西安市灵活就业社保缴费截止时间
  • 上海房产税2021征收对象
  • xboxone登录显示密码错误
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设