【Python复习巩固 Day6】多进程和多线程

本文探讨了多任务在操作系统中的实现,重点介绍了Python中的多进程和多线程。通过创建Process实例和使用进程池展示了多进程操作,强调了使用Queue实现进程间通信。同时,解释了Python的GIL锁限制了多线程的并行计算能力,但可通过多进程实现多核利用。最后,提到了多线程在Python中的应用和限制,并鼓励读者交流指正。
摘要由CSDN通过智能技术生成

现代很多操作系统都是支持多任务的操作系统,简单的说,就是操作系统可以同时运行多个任务,你可以一边听音乐,一边打游戏,这就是多任务

对操作系统来说,一个任务就是一个进程(Process),有些进程不止做一件事情,在进程内部,要同时干多件事情,就需要同时运行多个子任务,我们把进程内的这些子任务称为线程(Thread)

线程是最小的执行单元,而进程由至少一个线程组成。如何调度进程和线程,完全由操作系统决定,程序自己不能决定什么时候执行,执行多长时间

多任务的实现方式

  • 多进程模式
  • 多线程模式
  • 多进程+多线程模式

Python既支持多进程,又支持多线程

多进程

"""
多进程
"""
from multiprocessing import Process
import os


def run_process(name):
    print('Run child process %s (%s)' % (name, os.getpid()))


if __name__ == '__main__':
    print('Parent process %s' % os.getpid())
    p = Process(target=run_process, args=('process1', ))
    p.start()
    p.join()
    print('Child process end')

Parent process 13728
Run child process process1 (9944)
Child process end

Process finished with exit code 0

创建子进程时,只需要传入一个执行函数和函数的参数,就可以创建一个Process实例了,可以用start()方法来启动,join()方法可以等待子进程结束后再继续往下运行,通常用于进程间的同步

如果我们要启动大量子进程,可以使用进程池的方式批量创建子进程

"""
进程池
"""
import os
import random
import time
from multiprocessing import Pool


def long_time_task(name):
    print('Run task %s (%s)' % (name, os.getpid()))
    start = time
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值