python多任务(multiprocessing进程)

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

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

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)多线程执行示意图:

python多任务(multiprocessing进程)_第2张图片

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

python多任务(multiprocessing进程)_第3张图片

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

python多任务(multiprocessing进程)_第4张图片python多任务(multiprocessing进程)_第5张图片

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

python多任务(multiprocessing进程)_第6张图片

代码示列:

python多任务(multiprocessing进程)_第7张图片python多任务(multiprocessing进程)_第8张图片

5、进程池

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

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

(2)、进程池的创建

python多任务(multiprocessing进程)_第9张图片

你可能感兴趣的:(python)