首页 > 编程语言 >python中的多线程及锁介绍

python中的多线程及锁介绍

时间:2024-03-03 19:11:48浏览次数:30  
标签:执行 GIL python threading 线程 进程 多线程 及锁

线程
CPU执行调度的最小单位。

不能独立存在,依赖进程存在。

一个进程至少有一个线程,叫做主线程,另外还有内核线程、用户线程。

线程之间共享内存。

线程之间的通信效率远高于进程间通信效率,线程之间切换代价也比进程小很多。

适用场景
Python的多线程适用于IO密集型任务。

多任务可以由多进程完成,也可以由一个进程内的多线程完成。

关系
进程是由若干线程组成的,一个进程至少有一个线程。

线程是通过一个进程派生出来的,进程结束,其派生的线程就全部死掉了,线程间共用进程的内存,线程奔溃也可能导致进程奔溃。

为什么需要线程锁
多线程和多进程最大的不同在于,多进程中,同一个变量,各自有一份拷贝存在于每个进程中,互不影响,而多线程中,所有变量都由所有线程共享,所以,任何一个变量都可以被任何一个线程修改,因此,线程之间共享数据最大的危险在于多个线程同时改一个变量,把内容给改乱了。

解决方案就是加锁。锁的好处就是确保了某段关键代码只能由一个线程从头到尾完整地执行,坏处当然也很多,首先是阻止了多线程并发执行,包含锁的某段代码实际上只能以单线程模式执行,效率就大大地下降了。其次,由于可以存在多个锁,不同的线程持有不同的锁,并试图获取对方持有的锁时,可能会造成死锁,导致多个线程全部挂起,既不能执行,也无法结束,只能靠操作系统强制终止。

GIL--全局锁
GIL的全称是Global Interpreter Lock (全局解释器锁)。

Python解释器由于设计时有GIL全局锁,导致了多线程无法利用多核。

Python的线程虽然是真正的线程,但解释器执行代码时,有一个GIL锁,任何Python线程执行前,必须先获得GIL锁,然后,每执行100条字节码,解释器就自动释放GIL锁,让别的线程有机会执行。这个GIL全局锁实际上把所有线程的执行代码都给上了锁,所以,多线程在Python中只能交替执行,即使100个线程跑在100核CPU上,也只能用到1个核。

缺陷
频繁线程切换代价高。

线程安全(GIL)。

共享还是独享
如果某些资源不独享会导致线程运行错误,则该资源就由每个线程独享,而其他资源都由进程里面的所有线程共享。

线程共享资源:

地址空间、全局变量、打开的文件、子进程、闹铃、信号与信号服务程序、记账信息。

线程独享资源:

程序计数器、寄存器、栈、状态字。

python的多线程模块
Python的标准库提供了两个模块:thread和threading,thread是低级模块,threading是高级模块,对thread进行了封装。

绝大多数情况下,我们只需要使用threading这个高级模块。

多线程写法
1、导入模块

import threading

2、产生对象,传递的target参数是一个函数,即worker是一个函数;可以给线程传线程的name;可以给线程传参数args,agrs必须是一个元组。

t = threading.Thread(target=worker,name='lyz',args=(1,))

3、执行线程

t.start()

threading 模块提供的方法
threading.currentThread(): 返回当前的线程变量。

threading.enumerate(): 返回一个包含正在运行的线程的list。正在运行指线程启动后、结束前,不包括启动前和终止后的线程。

threading.activeCount(): 返回正在运行的线程数量,与len(threading.enumerate())有相同的结果。

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

start():启动线程活动。

join(): 等待至线程中止。join()的作用是,在子线程完成运行之前,这个子线程的父线程将一直被阻塞。

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

getName(): 返回线程名。

setName(): 设置线程名。

多线程的注意事项
1、线程执行是无序的

2、生命周期:

python中,主线程会等待子线程结束之后才结束。

但是如果设置d.setDaemon(True)这个属性,则主线程结束,子线程就必须结束了。

3、阻塞:

如果你想让主线程等所有子线程执行完才执行主线程的任务:join()

t = threading.Thread(target=worker,name='lyz',args=(1,))

t.join()

4、默认情况下,多线程的无序性,操作全局变量是不安全的,所以有线程锁

from threading import Lock,Thread

然后生成锁对象:

lock = Lock()

申请锁:

lock.acquire()

释放锁:

lock.release()

参考:https://blog.csdn.net/weixin_61805348/article/details/125021831?utm_medium=distribute.pc_relevant.none-task-blog-2~default~baidujs_baidulandingword~default-0-125021831-blog-125350491.235^v43^pc_blog_bottom_relevance_base9&spm=1001.2101.3001.4242.1&utm_relevant_index=3

https://blog.csdn.net/weixin_41777118/article/details/130416802

https://www.cnblogs.com/weiman3389/p/6044940.html

 

标签:执行,GIL,python,threading,线程,进程,多线程,及锁
From: https://www.cnblogs.com/klb561/p/18050485

相关文章

  • centos7 安装python3.8
    #cd/usr/local#yum-ygroupinstall"Developmenttools"#yum-yinstallzlib-develbzip2-developenssl-develncurses-develsqlite-develreadline-develtk-develgdbm-develdb4-devellibpcap-develxz-devel#yuminstalllibffi-devel-ywgethttps:/......
  • python 与jupyter notebook 安装和环境配置
    一、pyhon环境安装下载Python:首先,从Python官方网站(https://www.python.org/downloads/)Download点击下载Python的安装程序运行安装程序:下载完成后,运行Python的安装程序。在安装过程中,确保勾选“AddPythontoPATH”选项,这样可以方便在命令行中使用Python自定义目录......
  • 多线程限流工具类-Semaphore
    Semaphore介绍Semaphore(信号量)是JAVA多线程中的一个工具类,它可以通过指定参数来控制执行线程数量,一般用于限流访问某个资源时使用。Semaphore使用示例需求场景:用一个核心线程数为6,最大线程数为20的线程池执行任务,但是要求最多只能同时运行3个线程代码:publicclassdemo{......
  • python邮件发送代码参考
    1.python邮件发送参考代码#!/usr/bin/python#-*-coding:UTF-8-*-importsmtplibfromemail.mime.imageimportMIMEImagefromemail.mime.textimportMIMETextfromemail.mime.multipartimportMIMEMultipartfromemail.headerimportHeader#第三方SMTP服务mail_host......
  • C#多线程
    在C#编程中,多线程是实现高效并发编程的关键技术之一。通过创建多个线程,程序可以同时执行多个任务,从而充分利用多核处理器的计算能力。本文将带你快速回顾C#多线程的基础知识,通过10分钟的学习,你将能够掌握多线程的核心概念,并学会使用C#语言创建和管理线程。一、多线程基础概念在C......
  • python环境安装与配置 Jupyter Notebook的环境配置
    浏览器上搜索python官网进入官网,点击downloads(下载的意思)在里面自行选择在这里选择需要的版本,点击即可选择自定义安装,勾选添加环境变量下一步全选,第三步修改安装路径,怎么方便怎么来安装成功后,点击键盘Windows+R键进入运行输入cmd进入后输入python可以查看python版本,......
  • python——异常
        在原本的tryexcept结构的基础上,Python 异常处理机制还提供了一个else块,也就是原有tryexcept语句的基础上再添加一个else块,即tryexceptelse结构。使用else包裹的代码,只有当try块没有捕获到任何异常时,才会得到执行;反之,如果try块捕获到异常,即便调用对......
  • 并发编程补充:基于多线程实现并发的套接字通信
    服务端:fromsocketimport*fromthreadingimportThreaddefcommunicate(conn):whileTrue:try:data=conn.recv(1024)ifnotdata:breakconn.send(data.upper())exceptConnectionResetError:......
  • Python环境安装与配置
    Python的环境安装与配置Python是一种流行的编程语言,它被广泛应用于数据分析、人工智能、Web开发等领域。在进行Python开发之前,首先需要安装和配置Python环境。本文将为大家介绍如何在Windows系统中安装和配置Python环境。一、下载Python安装版本文件首先在浏览器中打开Python官......
  • python——面向对象——知识汇总三
    Python封装机制及实现方法 封装(Encapsulation),即在设计类时,刻意地将一些属性和方法隐藏在类的内部,这样在使用此类时,将无法直接以“类对象.属性名”(或者“类对象.方法名(参数)”)的形式调用这些属性(或方法),而只能用未隐藏的类方法间接操作这些隐藏的属性和方法。    Pyt......