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)、功能:
(2)多线程执行示意图:
(3)多进程执行示意图:
(4)进程与进程之间是独立的(线程之间共享全局变量)
(5)通过队列(Queues)完成进程间的通信(解耦)
代码示列:
5、进程池
(1)、 通过压力测试与系统测试测出一个进程池能放多少进程,不管来多少任务(不确定有多少任务),都要通过进程池中的进程重复使用,不用创建新的用完过后摧毁浪费资源。
注:如果只有2-3个任务,就不需要创建进程池
(2)、进程池的创建