多进程和多线程的实现方法

多进程与多线程:

一个进程中至少有一个线程。

程序执行时,程序本身就是一个线程,成为主线程。

手动创建的线程,称为是子线程。

主线程执行中不会等待子线程执行完毕,会直接执行后面的代码。

多进程执行过程中需要进行多进程切换,多进程切换消耗的CPU资源较多。

多进程:

# 多进程:一个程序运行过程中,产生了多个进程

# n个正在运行的程序----至少n个进程
# 1个程序-----可能只有一个进程,也可能有多个进程


#引入进程类
from multiprocessing import Process
import time

#任务1
def run1():
	print("执行了任务1!")
	time.sleep(5)

#任务2
def run2():
	print("执行了任务2!")
	time.sleep(5)

#任务3
def run3():
	print("执行了任务3!")
	time.sleep(5)


#--------------------串行
# run1()
# run2()
# run3()


#--------------------并行
#创建进程对象
p1=Process(target=run1)  #(target=要执行的任务方法)
p2=Process(target=run2)
p3=Process(target=run3)

if __name__ == '__main__':
	p1.start() #启动进程,只能写道main中
	p2.start()
	p3.start()

多线程:

import threading
import time

def run(name):
	time.sleep(5)
	print(name,"执行了任务!")

#程序执行时,程序本身就是一个线程,称为主线程
#手动创建的线程,称为子线程
#主线程执行中不会等待子线程执行完毕,会直接执行后面代码

#创建线程对象
t1=threading.Thread(target=run,args=("t1",))
t2=threading.Thread(target=run,args=("t2",))
t3=threading.Thread(target=run,args=("t3",))

#启动线程
t1.start()
t2.start()
t3.start()

t1.join() #需要等待当前线程执行完毕,才能继续执行主线程
t2.join()
t3.join()

print("执行完毕!")

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值