标签:roc 协程 int 阈值 效率 title 分配 targe task
目录
为什么要并发?
程序默认执行方式就是串行,即程序自上而下,一行一行顺序执行,必须把当前任务执行完才能执行下一个,这样造成效率低
并发可以同时执行多个任务 来提高程序的效率
? 1.多进程 核心原理是多道技术
? 2.多线程
? 3.协程
进程指得是正在运行的程序,是操作系统调度以及进行资源分配的基本单位 。
多进程指的是同一时间有多个程序被装入内存并执行
多进程的核心原理是多道技术
1.空间复用
? 统一时间,加载多个任务到内存中,多个进程之间内存区域需要相互隔离,这种隔离是物理层面的隔离,其目的是为了保证数安全
2.时间复用
? 指的是,操作系统会在多个进程之间做切换执行
? 切换任务的两种情况
? 1.当一个进程遇到了IO操作 时会自动切换
? 2.当一个任务执行时间超过阈值会强制切换
? 注意:在切换前必须保存状态,以便后续恢复执行
简单的总结就是切换加保存
有了多道技术,计算机就可以同时并发的处理多个任务
? 串行 程序自上而下顺序执行
? 并发 在不同任务之间快速切换
? 并行 真正的同时执行 必须具备多核CPU
以上三个概念都是用于描述处理任务的方式
? 阻塞 指的是程序遇到了IO操作,无法继续执行代码时的一种状态
? 非阻塞 指的是程序没有遇到IO操作的一中状态
? 是程序的状态
? 阻塞 运行 就绪
其中运行和就绪是非阻塞状态
对于通用计算机而言.必须具备创建和销毁进程的能力
创建
1.用户的交互式请求 ,鼠标双击
2.由一个正在运行的程序 调用了开启进程的接口 . 例如subprocess
3.一个批处理作业开始
4.系统初始化
销毁:
1.任务完成 自愿退出
2.强制结束 taskkill kill 非自愿
3.程序遇到了异常
4.严重错误 比如访问了不该访问的内存
程序是 一堆代码放在一个文件中
进程是将代码从硬盘读取到内存然后执行产生的
进程是由程序产生的 ,一个程序可以产生多个进程
在linux中 进程具备父子关系,是一个树状结构 ,可以互相查找到对方
在windows 没有层级关系 , 父进程可以将子进程的句柄转让
PID 是当前进程的编号,PPID 是父进程的编号
访问PID与PPID :
import os
os.getpid()
os.getppid()
创建子进程的方式
1.导入multiprocessing中的Process类,实例化这个类指定要执行的任务 target
2.导入multiprocessing 中的Process类 继承这个类 覆盖run方法 将要执行的任务放入run中开启进程时会自动执行该函数
实例化子进程使用join函数会让主进程等待子进程执行完毕再继续执行
if __name__ == '__main__':
p = Process(target=task,name="老司机进程")
p.start()
p.join()
# print(p.name) #进程名
# p.daemon #守护进程
# p.join()
# print(p.exitcode) # 获取进程的退出码 就是exit()函数中传入的值
# print(p.is_alive()) # 查看进程是否存活
# print("zi",p.pid) # 获取进程id
# print(os.getpid())
# p.terminate() #终止进程 与strat 相同的是 不会立即终止,因为操作系统有很多事情要做
# print(p.is_alive())
孤儿进程 :当父进程已经结束 而子进程还在运行子进程就称为孤儿进程 ,有其存在的必要性,没有不良影响 。
僵尸进程 :当一个进程已经结束了但是,它仍然还有一些数据存在 ,此时称之为僵尸进程 。
标签:roc 协程 int 阈值 效率 title 分配 targe task
原文地址:https://www.cnblogs.com/yellowcloud/p/11122827.html