我的第十三篇博客《多线程一》

多线程基本介绍:有很多的场景中的事情是同时进行的,比如开车的时候手和脚共同来驾驶汽车,再比如唱歌跳舞也是可以同时进行的

在python中有一个内置模块可以专门来实现多线程 threading

多线程的创建:

1.通过函数创建:使用threading模块中的thread类,有一个target参数,这个参数需要我们传递一个函数对象,这个函数可以实现子线程的逻辑

在这里插入图片描述

2.通过类来创建

在这里插入图片描述

主线程和子线程的关系

1.主线程会等待子线程执行结束后,主线程在结束

在这里插入图片描述

2.threading.join()会使主线程等待子线程执行结束后再执行主线程

在这里插入图片描述

3.threading.setDaemon(布尔值) 会使主线程不等待子线程执行完毕就结束程序

在这里插入图片描述

查看线程的数量

print(threading.enumerate())

在这里插入图片描述

验证子线程的执行和创建

1.当调用Thread的时候,不会创建子线程

2.当调用Thread创建出来的实例对象的start方法的时候,才会创建子线程以及开始运行这个线程

在这里插入图片描述

多线程共享全局变量

在这里插入图片描述

线程间的资源竞争

一个线程写入,一个线程读取,没问题;当两个线程都写入时,如果数据过大,两个线程就会出现抢数据的情况,导致输出结果不对

在这里插入图片描述

互斥锁

当多个线程几乎同时修改某个共享数据的时候,需要进行同步控制某个线程,再要更改共享数据时,先将其锁定,此时资源的状态为‘锁定’,其他线程不能改变,只有等到该线程释放资源,将资源的状态变成‘非锁定’状态,其他的线程才能再次锁定该资源

创建锁:lock = threading.Lock()

锁定 : lock.acquire()

解锁: lock.release()

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值