Python 进程和线程详解(multiprocessing、threading)

1 概述

1.1 进程 VS 线程

进程
线程 1
线程 2
线程 N

举例说明:
进程:QQ.exe
线程:支撑 QQ.exe 运行的各个程序

1.2 优缺点

优点缺点
进程可用多核 CPU资源开销大
线程资源开销小只能单核 CPU

2 进程

2.1 三个步骤

# 1.导入进程包
import  ultiprocessing

# 2.通过进程类创建进程对象,参数名有
# target: 执行的目标任务名(函数名、方法名)
# name  : 进程名,一般不用设置
# group : 进程组,一般不用设置
进程对象 = ultiprocessing.Process(target=任务名)

# 3.启动进程
进程对象.start()

2.2 多进程

import multiprocessing
import time


# 唱歌
def sing():
    for i in range(3):
        print("唱歌...")
        time.sleep(1)


# 跳舞
def dance():
    for i in range(3):
        print("跳舞...")
        time.sleep(1)


if __name__ == '__main__':
    sing_process = multiprocessing.Process(target=sing)
    dance_process = multiprocessing.Process(target=dance)

    sing_process.start()
    dance_process.start()

2.3 带参数

参数描述
元组 args参数有顺序要求
字典 kwargs参数无顺序要求
import multiprocessing
import time


# 唱歌
def sing(num):
    for i in range(num):
        print("唱歌...")
        time.sleep(1)


# 跳舞
def dance(num):
    for i in range(num):
        print("跳舞...")
        time.sleep(1)


if __name__ == '__main__':
    sing_process = multiprocessing.Process(target=sing, args=(3,))
    dance_process = multiprocessing.Process(target=dance, kwargs={"num": 3})

    sing_process.start()
    dance_process.start()

2.3.1 元组参数 args

sing_process = multiprocessing.Process(target=sing, args=(3,))
sing_process.start()

2.3.2 字典参数 kwargs

sing_process = multiprocessing.Process(target=dance, kwargs={"num": 3})
sing_process.start()

2.4 获取进程编号

import os

print(os.getpid())  # 当前进程ID
print(os.getppid())  # 当前进程的父ID

2.5 设置进程守护

import multiprocessing
import time


# 工作
def work():
    for i in range(10):
        print("工作中...")
        time.sleep(0.5)


if __name__ == '__main__':
    work_process = multiprocessing.Process(target=work)
    
    # 设置守护进程
    work_process.daemon = True
    
    work_process.start()
    time.sleep(1)
    print("主进程执行已完成!")

设置守护进程的前后对比图:
在这里插入图片描述

3 线程

3.1 三个步骤

# 1.导入线程模块
import threading

# 2.通过线程类创建线程对象,参数名有
# target: 执行的目标任务名(函数名、方法名)
# name  : 线程名,一般不用设置
# group : 线程组,一般不用设置
线程对象 = threading.Thread(target=任务名)

# 3.启动线程执行任务
线程对象.start()

3.2 多线程

import threading
import time


# 唱歌
def sing():
    for i in range(3):
        print("唱歌...")
        time.sleep(1)


# 跳舞
def dance():
    for i in range(3):
        print("跳舞...")
        time.sleep(1)


if __name__ == '__main__':
    sing_process = threading.Thread(target=sing)
    dance_process = threading.Thread(target=dance)

    sing_process.start()
    dance_process.start()

3.3 带参数

  • 同进程
import threading
import time


# 唱歌
def sing(num):
    for i in range(num):
        print("唱歌...")
        time.sleep(1)


# 跳舞
def dance(num):
    for i in range(num):
        print("跳舞...")
        time.sleep(1)


if __name__ == '__main__':
    sing_process = threading.Thread(target=sing, args=(3,))
    dance_process = threading.Thread(target=dance, kwargs={"num": 3})

    sing_process.start()
    dance_process.start()

2.3.1 元组参数 args

sing_process = multiprocessing.Thread(target=sing, args=(3,))
sing_process.start()

2.3.2 字典参数 kwargs

sing_process = multiprocessing.Thread(target=dance, kwargs={"num": 3})
sing_process.start()

2.4 获取线程编号

import threading


def work():
    print(f"线程ID为: {threading.current_thread().ident}")


if __name__ == '__main__':
    work_thread = threading.Thread(target=work)

    work_thread.start()

2.5 设置线程守护

  • 同 进程
import threading
import time


# 工作
def work():
    for i in range(10):
        print("工作中...")
        time.sleep(0.5)


if __name__ == '__main__':
    work_thread = threading.Thread(target=work)

    # 设置守护线程
    work_thread.setDaemon(True)

    work_thread.start()
    time.sleep(1)
    print("主进程执行已完成!")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鱼丸丶粗面

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值