python中的线程和进程

本文详细介绍了Python中的多任务实现,包括并发、并行的概念,并通过实例展示了如何使用多进程来提高程序效率。同时,讲解了进程的创建、进程编号获取以及守护进程的设置。此外,还探讨了线程的创建、线程间的执行顺序以及守护线程的设定。最后,对比了进程和线程的优缺点,指出线程在资源开销上的优势和进程在多核利用上的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、多任务

1.1 多任务:同一时间执行多个任务,
eg:我们可以 或者同时打开多个窗口

1.2 原理:利用CPU的资源,提高程序的执行效率

1.3 多任务表现形式
并发:在一段时间内交替执行多个任务
eg:对于单核CPU处理多任务,操作系统轮流让各个任务交替执行
并行:在一段时间内真正的同时一起执行多个任务,任务数量小于或等于cpu核心数
eg:对于多核cpu处理多任务,每个cpu执行每个任务

在python中,如果想实现多任务可以使用多进程

二、进程

2.1 进程:是资源分配的最小单位,它是操作系统进行资源分配(CPU,内存,磁盘,网络)和调度运行的基本单位,一个程序就是一个进程
eg:正在运行的微信等就是一个进程(进程:重点在运行)
2.2 多进程:使用多进程可以实现多任务的编程

# 这就是一个主进程,先执行task1,在执行task2

def task1():
    print("小可爱")
    

def task2():
    print("小宝贝")
    

task1()
task2()

对于上述情况,假设代码多起来,必定浪费时间,如果我们可以让这些函数同时运行,这将会大大提升代码的效率,由此可以在主进程里创建多个子进程

2.3 如何创建其他进程
2.3.1 进程创建的步骤:
(1)导包

import multiprocessing
# from multiprocessing import Process

(2)通过进程类创建进程对象

对象 = multiprocessing.Process()
# 对象 = Process()

(3)启动进程执行任务

对象.start( )

2.3.2 通过进程类创建进程对象

对象 = multiprocessing.Process(target=任务名)

target:指定进程执行的 函数名/方法名
name:进程名,一般不用设置(py会默认Process_1、2、3…)
group:进程组,目前只能使用None(一般不设置)

2.3.3 给指定任务传参
args:以元组的方式给执行任务传参(要加,)元组传参按顺序
kwargs:以字典的方式给执行任务传参 字典传参按key

# 传1个参数
import multiprocessing
import time


def task1(n):
    for i in range(n):
        time
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值