广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python多线程编程,线程锁
  • 787
分享到

Python多线程编程,线程锁

线程多线程Python 2023-01-30 22:01:57 787人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

多线程threading 模块创建线程创建自己的线程类线程通信线程同步互斥方法线程锁@需要了解!!!   什么是线程? 线程也是一种多任务的编程方法,可以利用计算机多核资源完成程序的并发运行。 线程又被称为轻量级进程

多线程threading 模块创建线程创建自己的线程类线程通信线程同步互斥方法线程@需要了解!!!

 

  • 什么是线程?

    1. 线程也是一种多任务的编程方法,可以利用计算机多核资源完成程序的并发运行。
    2. 线程又被称为轻量级进程
  • 线程的特征

    1. 线程是计算机多核分配的最小单位
    2. 一个进程可以包含多个线程
    3. 线程也是一个运行的过程,消耗计算机资源,多个线程共享进程的资源和空间
    4. 线程的创建删除消耗的资源都远远比进程小
    5. 多个线程之间执行互不干扰
    6. 线程也有自己的特有属性,比如指令集ID

threading 模块创建线程

 

  • t=threading.Thread()

    • 功能:创建线程对象

    • 参数

      • name:线程名称,如果为空则为默认值,Tread-1,Tread-2,Tread-3
      • target:线程函数
      • args:元组,给线程函数按照位置传参
      • kwargs:字典,给县城函数按照键值传参
  • t.start():启动线程,自动运行线程函数

  • t.join([timeout]):回收进程

  • t.is_alive():查看线程状态

  • t.name():查看线程名称

  • t.setName():设置线程名称

  • t.daemon属性:默认主线成退出不影响分支线程继续执行,如果设置为True则分支线程随着主线程一起退出

    • 设置方法

      • t.daemon = True

      • t.setDaemon(Ture)

         
  •  1 #!/usr/bin/env python3
     2 from threading import Thread
     3 from time import sleep
     4 import os
     5 ​
     6 # 创建线程函数
     7 def music():
     8     sleep(2)
     9     print("分支线程")
    10 ​
    11 t = Thread(target = music)
    12 # t.start()   # ******************************
    13 print("主线程结束---------")
    14 ​
    15 '''没有设置的打印结果
    16 主线程结束---------
    17 分支线程
    18 '''
    19 ​
    20 '''设置为True打印结果
    21 主线程结束---------
    22 '''

     

  • threading.currentThread:获取当前线程对象

 

@此处代码示意子线程共享同一个进程内的变量

 
 1   #!/usr/bin/env python3
 2   from threading import Thread
 3   from time import sleep
 4   import os
 5   
 6   # 创建线程函数
 7   def music():
 8       global a
 9       print("a=",a)
10       a = 10000
11       for i in range(5):
12           sleep(1)
13           print("1212")
14   
15   a = 1
16   t = Thread(target = music)
17   t.start()
18   t.join()
19   print("主线程的a =",a)

 

创建自己的线程类

考察点:类的使用,调用父类的__init__方法,函数*传参和**传参

  
 1  
 2   
 3 from threading import Thread
 4 import time
 5 ​
 6 class MyThread(Thread):
 7     name1 = 'MyThread-1'
 8     def __init__(self,target,args=(), kwargs={}, name = 'MyThread-1'):
 9         super().__init__()
10         self.name = name
11         self.target = target
12         self.args = args
13         self.kwargs = kwargs
14     def run(self):
15         self.target(*self.args,**self.kwargs)
16 ​
17 def player(song,sec):
18     for i in range(2):
19         print("播放 %s:%s"%(song,time.ctime()))
20         time.sleep(sec)
21 ​
22 t =MyThread(target = player, args = ('亮亮',2))
23 ​
24 t.start()
25 t.join()
26 ​

 

线程通信

通信方法:由于多个线程共享进程的内存空间,所以线程间通信可以使用全局变量完成

注意事项:线程间使用全局变量往往要同步互斥机制保证通信的安全

线程同步互斥方法

  • event

  • e = threading.Event():创建事件对象

  • e.wait([timeout]):设置状态,如果已经设置,那么这个函数将阻塞,timeout为超时时间

  • e.set:将e变成设置状态

  • e.clear:删除设置状态

      
import threading
from time import sleep

def fun1():
    print("bar拜山头")
    global s
    s = "天王盖地虎"

def fun2():
    sleep(4)
    global s
    print("我把限制解除了")
    e.set()     # 解除限制,释放资源

def fun3():
    e.wait() # 检测限制
    print("说出口令")
    global s
    if s == "天王盖地虎":
        print("宝塔镇河妖,自己人")
    else:
        print("打死他")
    s = "哈哈哈哈哈哈"

# 创建同步互斥对象
e = threading.Event()
# 创建新线程
f1 = threading.Thread(target = fun1)
f3 = threading.Thread(target = fun3)
f2 = threading.Thread(target = fun2)
# 开启线程
f1.start()
f3.start()
f2.start()
#准备回收
f1.join()
f3.join()
f2.join()

 

线程锁

  • lock = threading.Lock():创建锁对象
  • lock.acquire():上锁
  • lock.release():解锁

也可以用过with来上锁

  
1 with lock:
2     ...
3     ...

 

 

@需要了解!!!

  • Python线程的GIL问题(全局解释器)

    Python---->支持多线程---->同步互斥问题---->加锁解决---->超级锁(给解释器加锁)---->解释器同一时刻只能解释一个线程--->导致效率低下

  • 后果

    一个解释器同一时刻只能解释执行一个线程,所以导致Python线程效率低下,但是当遇到io阻塞时线程会主动让出解释器,因此Pyhton线程更加适合高延迟的IO程序并发

  • 解决方案

    • 尽量使用进程完成并发(和没说一样)
    • 不适当用C解释器 (用C# ,JAVA)
    • 尽量使用多种方案组合的方式进行并发操作,线程用作高延迟IO
作者:Banl
出处:https://www.cnblogs.com/BanL/
----------------------------------------------------------------------

个性签名:青春用来挥霍,白头不知所措!

如果这篇文章对你有些帮助,记得在右下角点个“推荐”,拜谢!

 

 

 

 

 

 

 

 

 

--结束END--

本文标题: Python多线程编程,线程锁

本文链接: https://www.lsjlt.com/news/179576.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python多线程编程,线程锁
    多线程threading 模块创建线程创建自己的线程类线程通信线程同步互斥方法线程锁@需要了解!!!   什么是线程? 线程也是一种多任务的编程方法,可以利用计算机多核资源完成程序的并发运行。 线程又被称为轻量级进程 ...
    99+
    2023-01-30
    线程 多线程 Python
  • # Python 多线程和锁
    作者博客:http://zzir.cn/ 进程和线程 进程是执行中的计算机程序。每个进程都拥有自己的地址空间、内存、数据栈及其它的辅助数据。操作系统管理着所有的进程,并为这些进程合理分配时间。进程可以通过派生新的进程来执行其它任务,不过...
    99+
    2023-01-31
    多线程 Python
  • Python多线程编程
      一个串行程序需要从每个I/O终端通道来检测用户的输入,然而程序在读取过程中不能阻塞,因为用户输入的到达时间的不确定,并且阻塞会妨碍其他I/O通道的处理。由于串行程序只有唯一的执行线程,因此它需要兼顾执行的多个任务,确保其中的某个任务不会...
    99+
    2023-01-31
    多线程 Python
  • python 多线程编程
    使用回调方式 import time def countdown(n): while n > 0: print('T-minus', n) n -= 1 time.sleep...
    99+
    2023-01-31
    多线程 python
  • C#多线程之线程锁
    目录一、Mutex类二、Mutex的用途三、Semaphore信号量1、简介2、初始化3、WaitOne()和Release()四、Monitor类典型的生产者与消费者实例五、Loc...
    99+
    2022-11-13
  • python多线程线程锁的使用方法
    小编给大家分享一下python多线程线程锁的使用方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python的数据类型有哪些python的数据类型:1. 数字类...
    99+
    2023-06-14
  • python多线程socket编程--多
    Python中实现socket通信的服务端比较复杂,而客户端非常简单,所以客户端基本上都是用sockct模块实现,而服务 端用有很多模块可以使用,如下: 1、客户端 #!/usr/bin/env python #coding...
    99+
    2023-01-31
    多线程 python socket
  • Python并行编程多线程锁机制Lock与RLock实现线程同步
    目录什么是锁机制?Lock() 管理线程RLock() 与Lock()的区别什么是锁机制? 要回答这个问题,我们需要知道为什么需要使用锁机制。前面我们谈到一个进程内的多个线程的某些资...
    99+
    2022-11-11
  • Python线程锁
    多线程的优势:可以同时运行多个任务但是当多个线程同时访问共享数据时,可能导致数据不同步,甚至错误!so,不使用线程锁, 可能导致错误购买车票--线程锁[root@~]# cat test.py #-*- coding:utf-8 -*- i...
    99+
    2023-01-31
    线程 Python
  • Python多线程编程实例
    Python多线程编程 发布者:lanyulei,转载请注明出处:http://www.fdevops.com/p=517 下面多线程模块threading的方法注释,均来自于百度贴吧"学点编程吧"。 Thread: 表示一个线程的执行对象...
    99+
    2023-01-31
    多线程 实例 Python
  • python多线程互斥锁与死锁
    目录一、多线程间的资源竞争二、互斥锁1.互斥锁示例2.可重入锁与不可重入锁三、死锁一、多线程间的资源竞争 以下列task1(),task2()两个函数为例,分别将对全局变量num加一...
    99+
    2022-11-13
  • python并发编程之多线程编程
    一、threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 二、开启线程的两种方式 方式一: from threading import ...
    99+
    2023-01-31
    之多 线程 python
  • 多线程编程(3):线程池ThreadPo
    在面向对象编程中,经常会面对创建对象和销毁对象的情况,如果不正确处理的话,在短时间内创建大量对象然后执行简单处理之后又要销毁这些刚刚建立的对象,这是一个非常消耗性能的低效行为,所以很多面向对象语言中在内部使用对象池来处理这种情况,以提高性能...
    99+
    2023-01-31
    线程 多线程 ThreadPo
  • Python并发编程多进程,多线程及GIL全局解释器锁
    目录1. 并发与并行2. 线程与进程的应用场景2.1. 并行/并发编程相关的技术栈3. Python中的GIL是什么,它影响什么1. 并发与并行 所谓的并行(Parallelism)...
    99+
    2022-11-11
  • python多线程编程:如何优雅地关闭线程
    在并发编程中,我们可能会创建新线程,并在其中运行任务,可能由于一些原因,决定停止该线程。例如: 不再需要线程任务的结果了。应用程序正在关闭。线程执行可能已经出现了异常 关于python多线程编程知...
    99+
    2023-09-04
    python 开发语言
  • C#多线程之线程锁实例分析
    这篇文章主要介绍了C#多线程之线程锁实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#多线程之线程锁实例分析文章都会有所收获,下面我们一起来看看吧。一、Mutex类“mutex”是术语“互相排斥(mut...
    99+
    2023-06-30
  • python多线程————3、多线程间通
    1、共享变量 #通过共享变量 import time import threading url_list = [] def get_detail_html(): global url_list while True: ...
    99+
    2023-01-31
    多线程 python
  • C#多线程系列之多线程锁lock和Monitor
    目录1,Locklock 原型lock 编写实例2,Monitor怎么用呢解释一下示例设置获取锁的时效1,Lock lock 用于读一个引用类型进行加锁,同一时刻内只有一个线程能够访...
    99+
    2022-11-13
  • Java 多线程编程
    Java 多线程编程   目录 Java 多线程编程 一个线程的生命周 线程的优先级 创建一个线程 通过实现Runnable接口来创建线程 实例 通过继承Thread来创建线程 实例 Thread 方法 实例   线程的几个主要概念: 多线...
    99+
    2023-10-20
    python 开发语言
  • python3 多线程编程
    0.什么是线程 多线程模块 创建线程的方法 join()方法 4.isAlive()方法 name属性和daemon属性 6.线程的同步---锁 7.线程的同步---Event对象 8.线程的同步---Condition条件...
    99+
    2023-01-31
    多线程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作