Python实现多线程

本文详细介绍了Python中的线程概念,包括GIL、线程的两种调用方式、线程的实例方法如join()和Daemon,以及同步机制如锁、递归锁、条件变量event、信号量和线程队列。还通过线程队列实现了生产者消费者模型。
摘要由CSDN通过智能技术生成

一、什么是线程

线程 可以理解为在进程中独立运行的子程序,是操作系统能够运行调度的最小单位。

举个不是特别恰当的例子,比如你正在听歌,然后你突然发现一首歌特别好听,你就想下载下来,这个时候你想边听边下载,但是这个时候就有一个尴尬的事情,如果你只有一个进程,会造成你在下载的时候不能听歌;如果有多个进程,进程A负责听,进程B负责下载。这时候又会出现两个进程协作的问题,进程执行过程中拥有独立的内存单元,彼此间资源不共享,不停地切换进程会造成性能上的损伤。这时候,如果能有一个机制,可以使两个任务共享资源,这样就能解决进程通信问题,降低来回切换的损耗,那就非常好了。这,就是线程。

线程特点:
1. 一个进程至少有一个线程;
2. 多个线程共享内存;
3. 线程不能够独立执行,必须依存于进程

二、Python的GIL

在CPython中,全局解释器锁(GIL)是一个互斥锁,它可以防止多个本机线程同时执行Python字节码。这个锁是必需的,主要是因为CPython的内存管理不是线程安全的。(然而,由于GIL的存在,其他功能已经依赖于它所执行的保证。)

这就意味着:无论你启多少个线程,你有多少个cpu, Python在执行的时候在同一时刻只允许一个线程运行。

三、Python的线程与threading模块

3.1 两种调用方式

3.1.1 直接调用

import threading  #线程
import time


def Hi(num):
    print("hello %d" %num)
    time.sleep(3)
    print("world")


if __name__ == '__main__':

    t1=threading.Thread(target=Hi,args=(10,))  #创建一个线程对象
    t2=threading.Thread(target=Hi,args=(9,))  #创建一个线程对象
    
    t1.start() #启动线程
    t2.start() #启动另一个线程
  
    print("ending.........")
执行结果:
hello 10
hello 9
ending.........
(将在此处停留三秒)
world
world

3.1.2 继承式调用

import threading
import time


class MyThread(threading.Thread):

    def __init__(self,num):
        threading.Thread.__init__(self) #最好采用super()
        self.num = num

    def run(self):#定义每个线程要运行的函数

        print("running on number:%s" %self.num)

        time.sleep(3)

if __name__ == '__main__':

    t1 = MyThread(1)
    t2 = MyThread(2)
    t1.start()
    t2.start()
    
    print("ending......")

自定义一个类,继承 threading.Thread,然后重新 run 方法

执行结果:
running on number:1
running on number:2
ending......
(停留三秒,然后结束运行)

3.2 threading.Thread 的实例方法

3.2.1 join()&Daemon()

import threading
import time


def music():
    print("begin to listen %s"%time.ctime())
    time.sleep(3)
    print("stop to listen %s" % time.ctime())


def game():
    print("begin to play game %s" % time.ctime())
    time.sleep(5)
    print("stop to play game %s" 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值