python33day
内容回顾
概念
同步异步阻塞和非阻塞
同步阻塞:调用一个函数需要等待这个函数的执行结果,并且在执行这个函数的过程中CPU不工作
inp=input('>>>')
同步非阻塞:调用一个函数需要等待这个函数的执行结果,在执行这个函数的过程中CPU工作
ret=eval('1+2+3-4')
异步非阻塞:调用一个函数不需要等待这个函数的执行结果,并且在执行这个函数的过程中CPU工作
start()
异步阻塞:调用一个函数不需要等待这个函数的执行结果,在执行这个函数的过程中CPU不工作
#开启十个进程 异步的
#获取这个进程的返回值,并且能做到哪一个进程先结束,就先获取谁的返回值。
进程的三状态图
- 就绪 ----->操作系统调度 ---->运行 ----->遇到io操作 ----> 阻塞
- ----->时间片到了 ----> 就绪
进程和调度算法:短作业和长作业是有区别的,越长的作业被调度的没有短作业积极,每个io操作都会让你辛苦排队得来的执行CPU机会让给其他程序
- 先来先服务
- 短作业优先
- 分时的概念
- 多级反馈算法
进程开启和关闭
- 父进程 开启了 子进程
- 父进程 要负责给 子进程 回收子进程结束后的资源
今日内容
Process类拾遗
开启进程的另一种方法
from multiprocessing import Process
import os
import time class MyProcess(Process):
def __init__(self,a,b,c):
self.a=a
self.b=b
self.c=c
super().__init__()
def run(self):
time.sleep(1)
print(os.getppid(),os.getpid(),self.a,self.b,self.c) if __name__ == '__main__':
print('----->',os.getpid())
for i in range(10):
p=MyProcess(1,2,3)
p.start()
print(p.pid,p.ident)
print(p.name)
print(p.is_alive())
p.terminate() #强制结束一个子进程
print(p.is_alive())
time.sleep(0.01)
print(p.is_alive())
Process类的一些其他方法和属性
- name pid daemon
守护进程
import time
from multiprocessing import Process def son1():
while True:
print('in son1')
time.sleep(1) def son2():
for i in range(10):
print('in son2')
time.sleep(1) if __name__ == '__main__':
p1=Process(target=son1)
p1.daemon=True # 表示设置p1是一个守护进程
p1.start()
p2=Process(target=son2).start()
time.sleep(5)
print('in main')
# 主进程会等待所有的子进程结束,是为了回收子进程的资源
# 守护进程会等待主进程的代码执行结束后再结束,而不是等待整个主进程
# 守护进程结束和其他子进程的结束与否无关
进程同步---lock锁
- 抢票的时候,有人买了,票就会立刻少
进程之间通信--队列
- 生产者消费者模式
- 爬虫的时候
- 分布式操作:celery
- 本质:就是让生产数据和消费数据的效率达到平衡并最大化
- consumer producer
进程之间的数据共享----Manager
代码总行数3047+49=3096行
python33day的更多相关文章
随机推荐
- 【LeetCode】980. Unique Paths III解题报告(C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 回溯法 日期 题目地址:https://leetco ...
- 【LeetCode】775. Global and Local Inversions 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址: https://leetcode.com/problems/global-a ...
- 【LeetCode】433. Minimum Genetic Mutation 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址: https://leetcode. ...
- 51Nod 1264:线段相交(计算几何)
51Nod 1264:线段相交 Decision 给出平面上两条线段的两个端点,判断这两条线段是否相交(有一个公共点或有部分重合认为相交). 如果相交,输出"Yes",否则输出&q ...
- [数据结构]链表LinkList
目录 1.3 链表 1.3.1 头插法建立单链表 1.3.2 限制链表长度建立单链表 1.3.3 尾插法建立单链表 1.3.4 按序号查找单链表 1.3.5 按值查找单链表 1.3.6 链表的插入 1 ...
- [git]初始化项目文件到git分支
将本地和远程仓库关联并push本地项目 1.VCS -> import into Version Control -> Create Git Repository 选择项目文件 2 ...
- JQuery的安装与下载教程
网页中添加 jQuery 可以通过多种方法在网页中添加 jQuery. 您可以使用以下方法: 从 jquery.com 下载 jQuery 库 从 CDN 中载入 jQuery, 如从 Google ...
- IIS部署Python-django项目
1.安装CgiModule模块 首先,IIS要部署django项目,需要CgiModule模块的支持,所以首先我们要确认这个模块是否存在 打开IIS管理器: 我这里是存在的: 如果不存在,可以自行在控 ...
- Arrays.sort实现原理
Collections.sort方法底层就是调用的array.sort方法 比较器的方式 TimSort static void sort(Object[] a, int lo, int hi, Ob ...
- PowerShell 教程
随笔分类 - 教程 转载自:https://www.cnblogs.com/XiaoCY/category/1065141.html PowerShell 管道符之Where-Object的使用方法 ...