python多任务编程_python线程的多任务编程

多任务

多任务介绍

对于人来说,一边听歌,一边跳舞就是多任务。

对于电脑,简单的说,同一时间执行多个程序处理数据叫做多任务

多任务理解

单核CPU

9e2ae74f1a352a4303aa86f7e7e3be2f.png

单核cpu在处理多任务的时候是根据时间片轮转的方式进行的,比如执行QQ1us,然后切换微信执行1us,最后是执行钉钉1us,如此循环。因为cpu的切换速度过快,导致我们认为三个软件是同时执行的

多核cpu

d3ad2ef5ae0d3b33361bb4fec82b6051.png

并发:当cpu不能同时执行当前所有任务时,就会循环执行,是假的多任务

并行:当cpu可以同时执行当前所有任务时,是真的多任务

多任务的实现方式

实现多任务有三种方式:

线程

进程

协程

线程

线程介绍

线程是指在一个单独进程中,对于CPU和内存而言的多个工作单位,所有线程在进程中的资源都是共享的,包括全局数据、执行代码等。

线程的使用

先介绍三个方法

setDaemon(True): 主线程A中,创建了子线程B,并且在主线程A中调用了B.setDaemon(),这个的意思是,把主线程A设置为守护线程,这时候,要是主线程A执行结束了,就不管子线程B是否完成,一并和主线程A退出.

join(): 主线程A中,创建了子线程B,并且在主线程A中调用了B.join(),那么,主线程A会在调用的地方等待,直到子线程B完成操作后,才可以接着往下执行

enumerate(): 查看线程数量

使用

代码示例import threading

import datetime

def A():

print('函数A')

print(datetime.datetime.now())

def B():

print('函数B')

print(datetime.datetime.now())

if __name__ == '__main__':

# 指定线程到A()和B()函数里执行

t1 = threading.Thread(target=A)

t2 = threading.Thread(target=B)

# 执行线程

t1.start()

t2.start()

print('--end--')

从输出结果可以知道,两个线程是在同一时间一起执行的。不过因为抢占式的特点,最后一条语句print('--end--')有时会在子线程的前面执行。

join()方法的使用

如果我们想让print('--end--')在最后执行,可以用到join()方法,当子线程结束后,主线程才会结束。

join方法的使用,代码示例

import threading

import datetime

def A():

print('函数A')

print(datetime.datetime.now())

def B():

print('函数B')

print(datetime.datetime.now())

if __name__ == '__main__':

# 指定线程到A()和B()函数里执行

t1 = threading.Thread(target=A)

t2 = threading.Thread(target=B)

# 执行线程

t1.start()

t2.start()

t1.join()

t2.join()

print('--end--')

setDaemon()方法的使用

如果不想让主线程等待子线程完成后才结束,可以使用setDaemon

代码示例import threading

import time

def A():

for i in range(3):

print("A")

time.sleep(1)

if __name__ == '__main__':

t1 = threading.Thread(target=A)

t1.setDaemon(True) # 要放在线程开始之前

t1.start()

enumerate()的使用,查看线程数量

代码示例import threading

import datetime

def A():

print('函数A')

print(datetime.datetime.now())

def B():

print('函数B')

print(datetime.datetime.now())

if __name__ == '__main__':

# 创建两个主线程,指定线程到A()和B()函数里执行

t1 = threading.Thread(target=A)

t2 = threading.Thread(target=B)

# 执行线程

t1.start()

t2.start()

print(threading.enumerate())

print('--end--')

子线程的创建与执行

当我们调用start()方法时,子线程才会被创建,并且执行

继承Thread类创建线程

我们可以通过修改Thread类的run()方法里的代码,来完成重写run()方法

代码示例import threading

class T(threading.Thread):

def run(self):

self.a()

def a(self):

for i in range(3):

print('a')

if __name__ == '__main__':

t1 = T()

t1.start() # 当调用start()方法时,会主动调用run()方法

当我们调用start()方法时,会主动调用run()方法

多线程共享全局变量

代码示例import threading

def a():

global num

num += 1

print(f'a:{num}')

def b():

print(f'b:{num}')

if __name__ == '__main__':

num = 10

print(num)

t1 = threading.Thread(target=a)

t2 = threading.Thread(target=b)

t1.start()

t2.start()

print(num)

线程的传参

当用线程去函数里执行代码时,我们可以看到函数后边是没有括号()的,所以涉及到传参的时候我们该怎么解决这个问题?

解决方法

我们可以使用args参数进行传参,参数为元组

当我们想要传入字典时,可以使用kwargs进行传入

代码示例import threading

def a(x):

print(x)

def b(**kwargs):

print(kwargs)

if __name__ == '__main__':

num = 1

# 使用args参数进行传参

t1 = threading.Thread(target=a, args=(num,))

# 使用kwargs参数进行传入字典

t2 = threading.Thread(target=b, kwargs={"A": 1})

t1.start()

t2.start()

线程的资源抢占

代码示例import threading

def a(x):

global num

for i in range(x):

num += 1

print(f'a: {num}')

def b(x):

global num

for i in range(x):

num += 1

print(f'b: {num}')

if __name__ == '__main__':

num = 100

t1 = threading.Thread(target=a, args=(1000000, ))

t2 = threading.Thread(target=b, args=(1000000, ))

t1.start()

t2.start()

print(num)

运行结果

382b3d51cd3ac994fe51a14123e64e89.png

正常的结果应该是2000100,但是因为资源抢占导致数据不正确,使用锁就可以避免这个问题,下篇博客我会细讲怎么解决这个问题。

最后,有喜欢博主写的内容的伙伴可以点赞收藏加关注哦!

本文地址:https://blog.csdn.net/weixin_44604586/article/details/107091271

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/277554.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

简单分析Guava中RateLimiter中的令牌桶算法的实现

为什么80%的码农都做不了架构师?>>> 令牌桶算法是网络流量整形(Traffic Shaping)和速率限制(Rate Limiting)中最常使用的一种算法。典型情况下,令牌桶算法用来控制发送到网络上的数据的数目&am…

gcc oracle mysql_Linux下C语言访问Oracle数据库Demo

前提条件1. Linux环境已经存在,安装好了Oracle本demo 运行环境本地环境 RedHat LINUX AS 4 ,ORACLE 10G本地数据库sid orcl,ip:127.0.0.1,用户名:kingbi,密码:kingbi,表dsd_test. 显示表dsd_test 的所有记录.步骤:(1) 创建表 …

炼数成金数据分析课程---16、机器学习中的分类算法(交叉内容,后面要重点看)...

炼数成金数据分析课程---16、机器学习中的分类算法(交叉内容,后面要重点看) 一、总结 一句话总结: 大纲实例快速学习法 主要讲解常用分类算法(如Knn、决策树、贝叶斯分类器等)的原理及python代码实现 1、什么是分类? 分…

NFS配置详解

1、NFS服务介绍1.1 什么是NFS?NFS是Network File System的缩写。中文意思是网络文件系统。它的主要功能是通过网络(一般是局域网)让不同的主机系统之间可以共享文件或者目录。NFS客户端(一般为应用服务器,例如web&…

idea用法

更新gradle的依赖后,刷新项目引入jar包的方法: view--Tool Buttons 在右侧 Gradle 点刷新 转载于:https://www.cnblogs.com/z360519549/p/10994897.html

免费下载!5本阿里技术好书,带你看更大的世界

共享、开源是互联网技术发展的重要精神。在过去,25000多万名阿里工程师,撰写了一系列精品技术丛书,从算法、研发到职业人生随笔,应有尽有。目前该系列丛书已全部开放下载,供技术人免费阅读。 今天小编整理了其中的五本…

乌班图系统16.04安装

本例jiyu基于Ubuntu16.04 64位版本为例进行安装,安装的方式有多种,本文使用光盘进行安装安装前应准备好,将Ubuntu的镜像文件刻成光盘,然后将光盘放入光驱,并设置服务器从光盘启动,开机到如下界面:按Enter键到下一步,如…

使用maven构建项目候,jar包错误的解决办法

1、删除架包,重新下载,右键项目点击"run as"中的“maven clean”,然后再maven中找到Update Project 2、可以在代码中,把鼠标放到报错的架包上 点击划红线部分,进行安装 转载于:https://www.cnblogs.com/qingqian/p/1099…

模拟输入(ADC-A0)

ESP8266具有内置的10位ADC,只有一个ADC通道(A0引脚),即只有一个ADC输入引脚可读取来自外部器件的模拟电压 ESP8266上的ADC通道和芯片供电电压复用,也就是说我们可以将其设置为测量系统电压或者外部电压 测量外部电压: analogRead(…

个人作业-Alpha项目测试

这个作业属于哪个课程https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2作业地址https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2/homework/3340团队名称脑阔疼https://www.cnblogs.com/chaserFF/p/10994338.html这个作业的目标完成班级项目互评…

Jenkins的Pipeline脚本在美团餐饮SaaS中的实践

2019独角兽企业重金招聘Python工程师标准>>> 一、背景 在日常开发中,我们经常会有发布需求,而且还会遇到各种环境,比如:线上环境(Online),模拟环境(Staging)&…

【springboot+easypoi】一行代码搞定excel导入导出

原文:https://www.jianshu.com/p/5d67fb720ece 开发中经常会遇到excel的处理,导入导出解析等等,java中比较流行的用poi,但是每次都要写大段工具类来搞定这事儿,此处推荐一个别人造好的轮子【easypoi】,下面…

用java编写一个计算器_用java程序编写一个计算器

展开全部给你一个参考,希望不62616964757a686964616fe58685e5aeb931333330343261要被百度吞了当晚餐import java.awt.BorderLayout;import java.awt.GridLayout;import java.awt.event.MouseEvent;import java.awt.event.MouseListener;import java.text.DecimalFor…

jquery中的ajax方法(备忘)

参考:https://www.cnblogs.com/tylerdonet/p/3520862.html w3school:http://www.w3school.com.cn/jquery/ajax_ajax.asp 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址。 2.type: 要求为String类型的参数&…

第4次作业

转载于:https://www.cnblogs.com/wzh2920330283/p/11027254.html

多核学习方法介绍

通过上篇文章的学习,我们知道,相比于单个核函数,多核模型可以具有更高的灵活性。经过多个核函数映射后的高维空间是由多个特征空间组合而成的组合空间,而显然组合空间可以组合各个子空间不同的特征映射能力,能够将异构…

linux go环境安装和基本项目结构

最近项目中要用到Go语言,所以简单总结一下安装和配置,Go这个语言本身就限定了很多规范,比如项目设置,编程风格等,开发中就不需要再因为各种规范问题纠结了,直接用官方规定的能避免很多坑,下面直…

运输层

运输层-TCP 简介 通俗点来说,运输层是连接底层和用户层的,运输层向它上面的应用层提供通信服务,它属于通信部分的最高层,同时也是用户功能的最低层。 运输层重要功能是复用和分用。复用:发送方不同应用进程可以使用同一…

phpStudy

很多朋友在学习php的过程中会看到phpstudy这个东西,那么phpstudy是做什么的呢?有什么用?接下来的这篇文章将个大家来详细的介绍一下phpstudy的内容。 首先在百度百科上对于phpstudy的定义是一个PHP调试环境的程序集成包。 该程序包集成最新的…

厉害了!Intel第九代酷睿参数曝光

2019独角兽企业重金招聘Python工程师标准>>> 导读上周有消息称,Intel第九代酷睿处理器最快于8月1日发布,共有三款主打产品,分别是i9-9900K、i7-9700K和i5-9600K。其中,i9-9900K设计为8核16线程,基础主频3.6…