系列文章目录
进程、程序的概念
进程以及状态
用process完成多进程
进程和线程的区别
一、进程、程序的概念
通俗一点讲,程序就是没有运行的,进程就是在运行的。同一个程序可以多个进程(qq,微信多开),程序是一个静态的,进程运行起来后,它是有操作系统分配资源的基本单位。
大区别:程序在没有运行起来时,是没有资源的,没有显卡,没有网卡等等,只要运行起来它就有网络,有摄像头,有键盘,鼠标,有内存等等。
我们不仅可以用线程完成多任务,进程也是可以的
二、进程以及状态
工作中,任务数往往大于CPU的核数,既一定有一些任务正在执行,而另外一些任务在等待CPU进行执行,因此导致了有了不同的状态
·就绪态:运行的条件都已经满足,正在等CPU执行
·执行态:CPU正在执行其功能
·等待态“等待某些条件满足,例如某一个程序sleep了,此时就处于等待态
三、用process完成多进程
操作:
代码:
import time
import multiprocessing
def test1():
while True:
print("1----")
time.sleep(1)
def test2():
while True:
print("2----")
time.sleep(1)
def main():
t1 = multiprocessing.Process(target=test1)
t2 = multiprocessing.Process(target=test2)
t1.start()
t2.start()
if __name__ == "__main__":
main()
输出结果:
思路和线程的思路是一样的,只是把threading换成了multiprocessing,一样的有一个主进程,和两个子进程
四、进程和线程的区别
进程:能够完成多任务,是资源分配的单位。比如在同一台电脑运行多个qq
线程:能够完成多任务,是操作系统调度的单位。比如一个qq中的多个聊天窗口
优缺点:线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程是相反的
最后:必须要先有进程,再有线程