Python threading和Thread模块及线程的实现

目录
  • 前言
  • 1. 线程
    • 1.1 线程模块
      • 1.1.1 Thread类
    • 1.2 创建线程
      • 1.2.1 实例Thread类法创建线程
      • 1.2.1 继承重写Thread类法创建线程
    • 1.3 Join & setDaemon
      • 1.3.1 join
      • 1.3.2 setDaemon

前言

  • 进程: 打开一个程序至少会有一个进程  它是cpu调度的最小的单位。
  • 线程: 程序执行的最小单位,一个进程里面至少有一个线程,cpu会控制进程里面的线程。

打个比方:

  • (1)打开一个qq就是一个进程的话,那么你可以同时和好多人聊天,和一个人聊天这就是一个线程。
  • (2)再打个比方,一条直行的高速公路,分好几个车道,这整个告诉公路就相当于一个进程,那些车道就相当于一个个线程,如果有一条车道上的车拐弯,别的车道的车就要等待,不然就撞车了。

注意:

  • (1)一个cpu同一时间只能处理一件事,如果同时有多个任务,那么就轮换着执行,但是每个任务执行的时间非常短暂,无法感受到。
  • (2)使用线程的时候,不管它的顺序,因为cpu是随机调度的。
  • (3)一个程序的执行,就会有一个主线程

1. 线程

1.1 线程模块

  • Python通过两个标准库thread 和threading提供对线程的支持 , threading对thread进行了封装。threading模块中提供了Thread , Lock , RLock , Condition等组件。
  • 因此在实际的使用中我们一般都是使用threading。

1.1.1 Thread类

常用参数说明:

  • target:表示调用对象,即子线程要执行的任务。
  • name:子线程的名称。
  • args:传入target函数中的位置参数,是一个元组,必须加逗号。

常用实例方法:

  • Thread.run(self)

线程启动时运行的方法,由该方法调用target参数所指定的函数。

  • Thread.start(self)

启动线程,start方法就是去帮你调用run方法。

  • Thread.terminate(self)

强制终止线程。

  • Thread.join(self, timeout=None)

阻塞调用,主线程进行等待。

  • Thread.setDaemon(self, daemonic)

将子线程设置为守护线程。

  • Thread.getName(self, name)

获取线程名称。

  • Thread.setName(self, name)

设置线程名称:

但是刚刚也讲了实际使用中我们都是使用的threading模块,所以此处只是简单介绍一下Thread类,下面讲解都是使用的threading模块!

1.2 创建线程

在python中创建线程有两种方式:

  • 实例Thread类;
  • 继承重写Thread类。

1.2.1 实例Thread类法创建线程

(需要注意的是:下面在主线程里添加了t1,t2两个子线程,①如果没有设置setDaemon守护线程,那么整个文件顺序执行完[即主线程]之后,对应的两个子线程并行执行;②如果设置了守护线程,那么对应的设置了守护线程的子线程在主线程执行完之后立马被杀死!)

# -*- coding: utf-8 -*-
import threading
import time

# 定义线程要运行的函数
def sing():
    # 为了便于观察,sleep1秒
    for i in range(5):
        print("正在唱歌......")
        time.sleep(1)

def dance():
    # 为了便于观察,sleep1秒
    for i in range(5):
        print("正在跳舞......")
        time.sleep(1)

if __name__ == '__main__':
    # 创建两个线程实例
    t1 = threading.Thread(target=sing)
    t2 = threading.Thread(target=dance)
    # 设置守护线程
    t1.setDaemon(True)    # 守护线程:把子线程作为主线程的守护线程
    t2.setDaemon(True)
    # 启动线程
    t1.start()
    t2.start()
    print('主线程结束')

未设置t1,t2为守护线程时的输出:

设置t1,t2为守护线程时的输出:

1.2.1 继承重写Thread类法创建线程

# -*- coding: utf-8 -*-
import threading
import time

# 继承threading中的Thread类
class MyThread(threading.Thread):
    # 线程中所需要的参数
    def __init__(self, name):
        super().__init__()
        self.name = name
    # 重构run方法,注意这个是表示线程活动的方法,必须有!
    def run(self):
        print('I am %s' % self.name)
        time.sleep(2)

# 创建线程实例
t1 = MyThread('guhanzhe')
t2 = MyThread('coolboy')
# 启动线程
t1.start()
t2.start()
# 打印线程名
print(t1.getName())
print(t2.getName())

1.3 Join & setDaemon

在说这两个方法之前 , 需要知道主线程与子线程的概念:

  • 主线程 : 当一个程序启动时 , 就有一个线程开始运行 , 该线程通常叫做程序的主线程。
  • 子线程 : 因为程序是开始时就执行的 , 如果你需要再创建线程 , 那么创建的线程就是这个主线程的子线程。

主线程的重要性体现在两方面 :

  • 是产生其他子线程的线程;
  • 通常它必须最后完成执行比如执行各种关闭操作。

1.3.1 join

  • join : 阻塞调用程序 , 直到调用join () 方法的线程执行结束, 才会继续往下执行。
# -*- coding: utf-8 -*-
import threading
import time

def run(name):
    print('I am %s' % name)
    time.sleep(2)
    print('子线程结束......')

t1 = threading.Thread(target=run, args=('guhanzhe', ))
t1.start()
# 阻塞主线程,等待子线程运行结束
t1.join()
print('主线程结束......')

大家可以尝试不加join()的话输出是什么样的哦~

1.3.2 setDaemon

  • setDaemon() 与 join() 基本上是相对的 , join会等子线程执行完毕 ; 而setDaemon则不会等,主线程结束,对应的设置了守护线程的子线程也会立马被杀死。
# -*- coding: utf-8 -*-
import threading
import time

def run(name):
    print('I am %s' % name)
    time.sleep(2)
    print('子线程结束......')

t1 = threading.Thread(target=run, args=('guhanzhe', ))
# 设置守护线程
t1.setDaemon(True)
t1.start()
print('主线程结束......')

到此这篇关于Python threading和Thread模块及线程的实现的文章就介绍到这了,更多相关Python线程实现内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python 使用threading+Queue实现线程池示例

    一.线程池 1.为什么需要使用线程池 1.1 创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处理效率. 记创建线程消耗时间T1,执行任务消耗时间T2,销毁线程消耗时间T3,如果T1+T3>T2,那说明开启一个线程来执行这个任务太不划算了!在线程池缓存线程可用已有的闲置线程来执行新任务,避免了创建/销毁带来的系统开销. 1.2 线程并发数量过多,抢占系统资源从而导致阻塞. 线程能共享系统资源,如果同时执行的线程过多,就有可能导致系统资源不足而产生阻塞的情况. 1.3 对线

  • Python线程协作threading.Condition实现过程解析

    领会下面这个示例吧,其实跟java中wait/nofity是一样一样的道理 import threading # 条件变量,用于复杂的线程间同步锁 """ 需求: 男:小姐姐,你好呀! 女:哼,想泡老娘不成? 男:对呀,想泡你 女:滚蛋,门都没有! 男:切,长这么丑, 还这么吊... 女:关你鸟事! """ class Boy(threading.Thread): def __init__(self, name, condition): supe

  • Python3 socket即时通讯脚本实现代码实例(threading多线程)

    Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高级别的网络服务模块 SocketServer, 它提供了服务器中心类,可以简化网络服务器的开发. ------------------------------------------------服务端代码-------------------------------------- __author__ = "

  • Python中多线程thread与threading的实现方法

    学过Python的人应该都知道,Python是支持多线程的,并且是native的线程.本文主要是通过thread和threading这两个模块来实现多线程的. python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便的被使用. 这里需要提一下的是python对线程的支持还不够完善,不能利用多CPU,但是下个版本的python中已经考虑改进这点,让我们拭目以待吧. threading模块里面主要是对一些线程的操作对象化了,创建

  • python中threading和queue库实现多线程编程

    摘要 本文主要介绍了利用python的 threading和queue库实现多线程编程,并封装为一个类,方便读者嵌入自己的业务逻辑.最后以机器学习的一个超参数选择为例进行演示. 多线程实现逻辑封装 实例化该类后,在.object_func函数中加入自己的业务逻辑,再调用.run方法即可. # -*- coding: utf-8 -*- # @Time : 2021/2/4 14:36 # @Author : CyrusMay WJ # @FileName: run.py # @Software:

  • Python用threading实现多线程详解

    多线程 多线程是个提高程序运行效率的好办法,本来要顺序执行的程序现在可以并行执行,可想而知效率要提高很多.但是多线程也不是能提高所有程序的效率.程序的两个极端是'CPU 密集型'和'I/O 密集型'两种,多线程技术比较适用于后者,因为在串行结构中当你去读写磁盘或者网络通信的时候 CPU 是闲着的,毕竟网络比磁盘要慢几个数量级,磁盘比内存慢几个数量级,内存又比 CPU 慢几个数量级.多线程技术就可以同时执行,比如你的程序需要发送 N 个 http 数据包(10 秒),还需要将文件从一个位置复制到另

  • Python中threading库实现线程锁与释放锁

    控制资源访问 前文提到threading库在多线程时,对同一资源的访问容易导致破坏与丢失数据.为了保证安全的访问一个资源对象,我们需要创建锁. 示例如下: import threading import time class AddThread(): def __init__(self, start=0): self.lock = threading.Lock() self.value = start def increment(self): print("Wait Lock") se

  • python使用threading获取线程函数返回值的实现方法

    threading用于提供线程相关的操作,线程是应用程序中工作的最小单元.python当前版本的多线程库没有实现优先级.线程组,线程也不能被停止.暂停.恢复.中断. threading模块提供的类:  Thread, Lock, Rlock, Condition, [Bounded]Semaphore, Event, Timer, local. threading 模块提供的常用方法: threading.currentThread(): 返回当前的线程变量. threading.enumera

  • python基于queue和threading实现多线程下载实例

    本文实例讲述了python基于queue和threading实现多线程下载的方法,分享给大家供大家参考.具体方法如下: 主代码如下: #download worker queue_download = Queue.Queue(0) DOWNLOAD_WORKERS = 20 for i in range(DOWNLOAD_WORKERS): DownloadWorker(queue_download).start() #start a download worker for md5 in MD5

  • Python threading和Thread模块及线程的实现

    目录 前言 1. 线程 1.1 线程模块 1.1.1 Thread类 1.2 创建线程 1.2.1 实例Thread类法创建线程 1.2.1 继承重写Thread类法创建线程 1.3 Join & setDaemon 1.3.1 join 1.3.2 setDaemon 前言 进程: 打开一个程序至少会有一个进程  它是cpu调度的最小的单位. 线程: 程序执行的最小单位,一个进程里面至少有一个线程,cpu会控制进程里面的线程. 打个比方: (1)打开一个qq就是一个进程的话,那么你可以同时和好

  • Python 常用模块threading和Thread模块之线程池

    目录 1. 池的概念 2. 自定义线程池 3. 使用Python内置线程池 4. 池的其他操作 1. 池的概念 主线程: 相当于生产者,只管向线程池提交任务. 并不关心线程池是如何执行任务的. 线程池: 相当于消费者,负责接收任务,并将任务分配到一个空闲的线程中去执行.并不关心是哪一个线程执行的这个任务. 2. 自定义线程池 # -*- coding: utf-8 -*- from threading import Thread from queue import Queue import ti

  • Python常用模块之threading和Thread模块

    目录 1. 线程通信 1.1 互斥锁 1.2 线程间全局变量的共享 1.3 共享内存间存在竞争问题 1.4 使用锁来控制共享资源的访问 分析此阶段,我们会发现进程和线程的痛点!!! 2. 队列的基本概念 总结 1. 线程通信 1.1 互斥锁 在多线程中 , 所有变量对于所有线程都是共享的 , 因此 , 线程之间共享数据最大的危险在于多个线程同时修改一个变量 , 那就乱套了 , 所以我们需要互斥锁 , 来锁住数据. 1.2 线程间全局变量的共享 注意: 因为线程属于同一个进程,因此它们之间共享内存

  • python threading和multiprocessing模块基本用法实例分析

    本文实例讲述了python threading和multiprocessing模块基本用法.分享给大家供大家参考,具体如下: 前言 这两天为了做一个小项目,研究了一下python的并发编程,所谓并发无非多线程和多进程,最初找到的是threading模块,因为印象中线程"轻量...","切换快...","可共享进程资源..."等等,但是没想到这里水很深,进而找到了更好的替代品multiprocessing模块.下面会讲一些使用中的经验. 后面出现的

  • Python多线程threading和multiprocessing模块实例解析

    本文研究的主要是Python多线程threading和multiprocessing模块的相关内容,具体介绍如下. 线程是一个进程的实体,是由表示程序运行状态的寄存器(如程序计数器.栈指针)以及堆栈组成,它是比进程更小的单位. 线程是程序中的一个执行流.一个执行流是由CPU运行程序代码并操作程序的数据所形成的.因此,线程被认为是以CPU为主体的行为. 线程不包含进程地址空间中的代码和数据,线程是计算过程在某一时刻的状态.所以,系统在产生一个线程或各个线程之间切换时,负担要比进程小得多. 线程是一

  • Python Threading 线程/互斥锁/死锁/GIL锁

    导入线程包 import threading 准备函数线程,传参数 t1 = threading.Thread(target=func,args=(args,)) 类继承线程,创建线程对象 class MyThread(threading.Thread) def run(self): pass if __name__ == "__main__": t = MyThread() t.start() 线程共享全面变量,但在共享全局变量时会出现数据错误问题 使用 threading 模块中的

  • 对python:threading.Thread类的使用方法详解

    Python Thread类表示在单独的控制线程中运行的活动.有两种方法可以指定这种活动: 1.给构造函数传递回调对象 mthread=threading.Thread(target=xxxx,args=(xxxx)) mthread.start() 2.在子类中重写run() 方法 这里举个小例子: import threading, time class MyThread(threading.Thread): def __init__(self): threading.Thread.__in

  • python threading模块的使用指南

    1. threding模块创建线程对象 接上述案例,我们可以利用程序阻塞的时间让程序执行后面的任务,可以用多线程的方式去实现.对应的需要我们借助threading模块去实现: 如下所示 import time import threading def work(): """只有函数对象才能佈田名线积""" print('5.洗茶杯: 1min ' ) time.sleep(1) print('6.放茶叶: 1min ' ) time.sleep(

  • Python threading模块中lock与Rlock的使用详细讲解

    目录 前言 1.Lock(互斥锁) 2.RLock(可重入锁) 前言 在使用多线程的应用下,如何保证线程安全,以及线程之间的同步,或者访问共享变量等问题是十分棘手的问题,也是使用多线程下面临的问题,如果处理不好,会带来较严重的后果,使用python多线程中提供Lock .Rlock .Semaphore .Event .Condition 用来保证线程之间的同步,后者保证访问共享变量的互斥问题. Lock & RLock:互斥锁,用来保证多线程访问共享变量的问题 Semaphore对象:Lock

随机推荐