一 传统编程的缺陷
传统编程的弊端:
2个任务花费的时间是10秒,如果要边跳边唱,其实2个任务是可以在最长的那个任务完成时全部完成的。
实现多任务编程的方式有很多,如:多进程、多线程、协程等。
二 使用多进程方式实现多任务
三 进程的一些操作
通过 htop
命令可以查看详细的进程列表。
注意:使用kill -9 pid
杀死主进程后,子进程不会被杀死,此时命令行也会无法正常退出,因为该命令的信号是发给了主进程来执行杀死任务,子进程由于没有父进程,变成了孤儿进程,之后被init进程领养。也就是说杀死主进程后,子进程的父进程称为了init进程。
通过 os.getpid()
可以获取到当前进程的pid,os.getppid()
可以获取父进程id。
四 进程间通信
进程之间无法直接进行通信,因为他们是互相独立的应用程序。
进程之间要实现通信,常见的方式有:socket等,python中可以使用队列方式实现:
五 进程池
六 多线程方式实现多任务
七 线程相关API
通过 threading.Thread()
可以创建线程,threading.enumerate()
也可以查看当前所有的线程:
八 同步与死锁
线程是共享全局变量的,这样就会造成数据的混乱:
使用互斥锁实现同步的方案: