[Python | CS基础 ]Python多线程`threading`和多进程`multiprocessing`

多线程和多进程的Python实现

1. 多线程实现

1.1 原理

  • Python的多线程模块**threading**允许程序并发执行多个任务。
  • 由于全局解释器锁(GIL),Python的线程可能无法实现真正的并行执行,适合I/O密集型任务。

1.2 示例代码

python 复制代码
import threading
import time

# 定义线程要执行的函数
def print_numbers(threadName, delay):
    count = 0
    while count < 5:
        time.sleep(delay)
        count += 1
        print(f"{threadName}: {count}")

# 创建线程对象
thread1 = threading.Thread(target=print_numbers, args=("Thread-1", 1,))
thread2 = threading.Thread(target=print_numbers, args=("Thread-2", 2,))

# 启动线程
thread1.start()
thread2.start()

# 等待线程执行结束
thread1.join()
thread2.join()

1.3 代码解释

  • print_numbers函数接受线程名称和延迟时间作为参数,并在循环中打印数字。
  • threading.Thread创建线程对象,target指定线程要执行的函数,args传递给函数的参数。
  • start()方法启动线程,join()方法等待线程完成。

2. 多进程实现

2.1 原理

  • Python的**multiprocessing**模块允许程序创建多个进程,每个进程有自己的内存空间和Python解释器,可以绕过GIL,适合计算密集型任务。

2.2 示例代码

python 复制代码
from multiprocessing import Process
import time

# 定义进程要执行的函数
def print_numbers(processName, delay):
    count = 0
    while count < 5:
        time.sleep(delay)
        count += 1
        print(f"{processName}: {count}")

# 创建进程对象
process1 = Process(target=print_numbers, args=("Process-1", 1,))
process2 = Process(target=print_numbers, args=("Process-2", 2,))

# 启动进程
process1.start()
process2.start()

# 等待进程执行结束
process1.join()
process2.join()

2.3 代码解释

  • print_numbers函数接受进程名称和延迟时间作为参数,并在循环中打印数字。
  • Process创建进程对象,target指定进程要执行的函数,args传递给函数的参数。
  • start()方法启动进程,join()方法等待进程完成。

3. 休眠的作用

3.1 原因

  • 模拟耗时操作:模拟文件读写、网络通信等耗时任务。
  • 避免过快执行:减慢执行速度,便于观察输出。
  • 展示并发效果:增加线程切换机会,展示并发执行效果。
  • 避免资源竞争:减少同时访问共享资源的可能性。
  • 控制执行顺序:通过调整休眠时间,影响执行顺序。
  • 测试和调试:帮助开发者理解执行流程,定位问题。

3.2 示例代码中的休眠

  • 在多线程和多进程的示例代码中,time.sleep(delay)用于休眠指定的时间(秒),其中delay是传递给函数的参数。
相关推荐
吴佳浩3 小时前
Python入门指南(六) - 搭建你的第一个YOLO检测API
人工智能·后端·python
superman超哥4 小时前
仓颉语言中基本数据类型的深度剖析与工程实践
c语言·开发语言·python·算法·仓颉
Learner__Q4 小时前
每天五分钟:滑动窗口-LeetCode高频题解析_day3
python·算法·leetcode
————A4 小时前
强化学习----->轨迹、回报、折扣因子和回合
人工智能·python
SAP小崔说事儿4 小时前
在数据库中将字符串拆分成表单(SQL和HANA版本)
java·数据库·sql·sap·hana·字符串拆分·无锡sap
徐先生 @_@|||5 小时前
(Wheel 格式) Python 的标准分发格式的生成规则规范
开发语言·python
川贝枇杷膏cbppg5 小时前
asmcmd
数据库·oracle
Mqh1807625 小时前
day45 简单CNN
python
JIngJaneIL5 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
IndulgeCui6 小时前
基于CentOS7 DM8单机部署配置记录-20251216
数据库