操做系统(英语:operating system,缩写做 OS)是管理计算机硬件与软件资源的计算机程序,同时也是计算机系统的内核与基石。操做系统须要处理如管理与配置内存、决定系统资源供需的优先次序、控制输入与输出设备、操做网络与管理文件系统等基本事务。操做系统也提供一个让用户与系统交互的操做界面。网络
操做系统简单介绍:并发
多道程序设计技术异步
空间复用函数
时间复用spa
进程之间是空间隔离的操作系统
分时系统设计
实时系统code
通用操做系统对象
并发:伪并行,看着像同时运行,实际上是任务之间的切换(遇到io切换的会提升代码效率) ,任务切换+保存状态(保存现场)blog
并行:真正的同时在运行,应用的是多核技术(多个cpu)
进程三状态:就绪(等待操做系统调度去cpu里面执行) 执行 阻塞
提交任务的方式:同步异步 任务的执行状态:阻塞非阻塞
异步:任务的提交方式,多个任务提交出去,同时执行
分类:
同步阻塞
异步阻塞:
异步非阻塞:
同步非阻塞:
进程的2种建立方式:
第一种:
import time from multiprocessing import Process def f1(): time.sleep(3) print('我同桌是猪') print(time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())) def f2(): time.sleep(3) print('还偷偷睡觉') print(time.strftime('%Y-%m-%d %H:%M:%S',time.localtime())) if __name__ == '__main__': p1 = Process(target=f1,) p2 = Process(target=f2, ) p1.start() p2.start()
第二种方式: 建立一个类,继承Process
from multiprocessing import Process class MyProcess(Process): def __init__(self,n): super().__init__() #别忘了执行父类的init self.n = n def run(self): print('%s快要睡着了'%self.n) if __name__ == '__main__': p1 = MyProcess('Jerry') p1.start()
传参方式:
from multiprocessing import Process # 演示两种传参方式 def f1(n): print(n) if __name__ == '__main__': # p1 = Process(target=f1,args=('Jerry',)) #建立进程对象 p1 = Process(target=f1,kwargs={'n':'Jerry'}) # 建立进程对象 kwargs={函数中的形参做为key:值} p1.start() #给操做系统发送了一个建立进程的信号,后续进程的建立都是操做系统的事儿了
for 循环建立进程:
import time from multiprocessing import Process def f1(i): time.sleep(3) print(i) if __name__ == '__main__': for i in range(20): p1 = Process(target=f1,args=(i,)) p1.start()
join()方法:主进程等待子进程运行完才继续执行
import time from multiprocessing import Process def f1(): time.sleep(2) print('我是f1') def f2(): time.sleep(2) print('我是f2') if __name__ == '__main__': p1 = Process(target=f1,) p1.start() p1.join() # 主进程等待子进程运行完才继续执行 print('p2来了') p2 = Process(target=f2,) p2.start() p2.join() print('我要等了...等个人子进程...') print('我是主进程!!!')