python多任务(multiprocessing进程)

1、程序就是代码,点击运行成2进制就是进程。一个程序有多个进程。

2、进程和线程都会执行多任务,但是子进程创建会把主进程的代码与数据复制一部份,这样耗费的资源比较大,但是比单任务效率高。(线程创建是资源共享的,因此耗费的资源少)

2、linux中查看进程(ps -aux) 所有进程

杀死进程(kill PID)

3、代码:

import multiprocessing(进程)

import threading(线程)

 

t1=threading.Thread(target=test1)(线程)

t2=threading.Thread(target=test2)(线程)

p1=multiprocessing.Process(target=test1)(进程)

p2=multiprocessing.Process(target=test2)(进程)

p1.start()

p2.start()

t1.start()

t2.start()

 

4、面试可能问到的问题:进程,线程的区别

注:一个QQ软件(代码)运行起来就是进程,同一时间可以运行多个qq软件,QQ里面实现多任务操作就是线程。一个进程运行起来必须有一个主线程,并且线程必须依赖进程才可以运行,没有进程就没有线程。

(1)、功能:

  • 进程,能够完成多任务,比如在一台电脑上能够同时运行多个qq(是资源分配的单位)
  • 线程,能够完成多任务,比如一个qq中的多个聊天窗口(是资源调度的单位)

(2)多线程执行示意图:

(3)多进程执行示意图:

(4)进程与进程之间是独立的(线程之间共享全局变量)

(5)通过队列(Queues)完成进程间的通信(解耦)

代码示列:

5、进程池

(1)、 通过压力测试与系统测试测出一个进程池能放多少进程,不管来多少任务(不确定有多少任务),都要通过进程池中的进程重复使用,不用创建新的用完过后摧毁浪费资源。

注:如果只有2-3个任务,就不需要创建进程池

(2)、进程池的创建

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值