Python并发编程

本文介绍了Python并发编程的基础概念,包括并行与并发的区别,进程与线程的关系,以及并发问题的解决策略。详细讲解了Python中创建线程的三种方式:函数、继承类和线程池,并展示了相关示例。此外,还探讨了线程安全和线程同步,介绍了Lock和RLock锁的使用,以及如何通过同步队列实现线程间的通信。
摘要由CSDN通过智能技术生成





1、基本概念

1.1、并行与并发


  • 并行:同一时间片并列执行
  • 并发:不同时间片交替执行

1.2、进程与线程


  • 进程是操作系统资源分配的基本单位,线程是CPU调度的基本单位

  • 进程之间不共享全局变量,线程之间共享全局变量(资源竞争问题)

1.3、并发问题解决思路


  • 构建队列、缓冲区:挨个执行不要拥挤
  • 构建锁:哪个线程抢到独占执行,其它线程等待,该线程执行完成后释放锁
  • 预处理:提前加载
  • 并行:多核CPU

2、Python中创建线程的3种方式


2.1、线程的状态

我们知道,线程共有5种状态:创建(New)、可运行(Runnable)、阻塞(Blocked)、运行(Running)、终止(Terminated)

通常情况下,线程从运行(Running)到进入阻塞(Blocked)状态有以下情况:

  • 睡眠sleep()
  • 等待wait(),此时需要其他线程通过notify()方法唤醒
  • 同步join(),阻塞主线程,等待子线程结束,即主线程任务结束之前,进入阻塞状态;获取线程锁,但是因为资源已经被其他线程占用时

Python提供的标准模块threading可用于多线程。Python中创建线程有以下3种方式:

  • 函数:使用threading模块创建:threading.Thread(func线程函数对象, args传递给线程函数的参数元组类型)

  • 继承类:使用threading模块创建,继承threading.Thread类,重写run()方法

  • 线程池:使用concurrent.futures模块创建线程池

2.2、函数创建

使用函数创建多线程的步骤如下:

  • 定义函数func(args)
  • 创建一个线程:t=threading.Thread(func, args)
  • 启动线程:t.start()
  • 线程阻塞、等待结束:t.join()

以下是一个示例:

import threading
import time

# 线程执行的函数
def worker(thread_name, delay):
    count = 10
    while count > 0:
        time.sleep(delay)
        count -= 1
        print(f"{
     thread_name} 抢到了,剩余: {
     count}")

# 创建2个线程,并开启
thread1 = threading.Thread(target=worker, args=('Thread-1', 1))
thread2 = threading.Thread(target=worker, args=('Thread-2', 2))
thread1.start()
thread2.start()

2.3、继承类创建

可以继承threading.Thread类,重写run()方法创建多线程。Thread类提供的方法有:

  • thread.start():启动线程
  • thread.join():资源独占,阻塞线程,等待结束(thread占用所有资源,该线程运行完毕后,其他线程才能执行)
  • thread.getName():返回线程名
  • thread.setName():设置线程名
  • thread.daemon=True/thread.setDaemon(True):设置thread线程为主线程的守护线程(会随着主线程的退出而退出,不论该线程是否执行完成)

以下是一个示例:

# Lock对象
lock = threading.Lock()
# 共享资源
count = 10

class MyThread(threading.Thread):

    def __init__(self, thread_name, delay):
        super(
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python并发编程是指使用Python编写并行执行的程序。它允许多个任务同时执行,提高程序的效率。在Python中,有多种方法可以实现并发编程,其中包括多线程、多进程和异步编程。多线程是指在一个程序中同时运行多个线程,每个线程执行一个任务。多进程是指在一个程序中同时运行多个进程,每个进程执行一个任务。异步编程是指通过回调函数或协程来实现并发执行任务的方式。这些方法可以根据需求选择合适的方式来进行并发编程并提高程序的性能。其中,学习Python并发编程推荐在Linux上学习,因为Linux系统对于进程之间的通信有较好的支持,而Mac系统的核心也是Linux,所以Linux上的任何Python代码在Mac上都是可行的。官方文档提供了有关Python并发编程的详细信息,可以在https://docs.python.org/3/library/multiprocessing.html进行查阅。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Python笔记.docx](https://download.csdn.net/download/bxy0806/88235414)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [深入浅出讲解Python并发编程](https://blog.csdn.net/wanger5354/article/details/122016057)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [python并发编程](https://blog.csdn.net/weixin_43915382/article/details/122003007)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值