#斐波那契
def fid(n):
res = []
indx = 0
a = 0
b = 1
while indx < n :
res.append(b)
a,b = b,a+b
indx += 1
return res print(fid(1000))

  

#  生成器
def fid(n):
indx = 0
a = 0
b = 1
while indx < n :
yield b # 暂停并返回 跳出函数
res.append(b)
a,b = b,a+b
indx += 1 f = fid(10)
print(f)
print(next(f))

  

#  生成器
import time def fid(n):
indx = 0
a = 0
b = 1
while indx < n :
data = yield b # 暂停并返回 跳出函数
time.sleep(data)
a,b = b,a+b
indx += 1 f = fid(10)
# # 使用 send 前,要 next 下
# f.__next__()
# 或者 先 send ( None )
f.send(None)
print(f.send(2))
print(f.send(2))
print(f.send(2))

  

#  协程 :非抢占式多任务子程序组件

import greenlet     #  pip install greenlet

from greenlet import greenlet

def tast_1():
print(11111)
gr2.switch()
print(22222) def tast_2():
print(33333)
print(44444)
gr1.switch() gr1 = greenlet(tast_1)
gr2 = greenlet(tast_2)
gr1.switch() # 调用协程, ######

11111
33333
44444
22222

  

#  协程   传参

import greenlet     #  pip install greenlet

from greenlet import greenlet

def tast_1():
print(11111)
a = gr2.switch() # 传参
print(22222)
print(a) def tast_2():
print(33333)
print(44444)
gr1.switch(123) # 传参 gr1 = greenlet(tast_1)
gr2 = greenlet(tast_2)
gr1.switch() # 调用协程, #########
11111
33333
44444
22222
123

  

遇到阻塞时自动切换,

#  gevent HTTP 请求

from gevent import monkey;monkey.patch_all()       #  猴子补丁
import gevent
'''当 greenlet 遇到一个 IO 操作垢时候 ,自动切换到其他的 greenlet'''
import requests
# import time def get_res(pn):
print('开始',pn)
requests.get('https://www.baidu.com') # 这里耗时发生阻塞
# time.sleep(3)
print('结束',pn) # gevent.spawn 启动协程
ta = [gevent.spawn(get_res,i) for i in range(5)]
# time.sleep(2)
gevent.joinall(ta)
# gevent.joinall(ta,timeout=1) # spawn 创建一个 gevent 的的协程对象,开始运行,
# 为什么 ta = [gevent.spawn(get_res,i) for i in range(5)]
# 不打印,?因为他运行为立马退出,不会打印,
# joinall 等待所有 greenlet 执行完毕,

  

如果没有使用猴子补丁

#  生产者与消费者

import gevent
import random
from queue import Queue # 队列
q = Queue(2) def con(): # 消费者
while True:
print(q.qsize())
iten = q.get()
print('删除一个数据{}'.format(iten)) def pro(): # 生产者
while True:
print(q.qsize())
iten = random.randint(0,99) # 如果没有猴子补丁,程序将阻塞在这里,
q.put(iten) print('添加一个数据{}'.format(iten)) p1 = gevent.spawn(pro)
c1 = gevent.spawn(con)
gevent.joinall([p1,c1])

  ########

0
添加一个数据32
1
添加一个数据22
2

在  gevent 有 queue 队列,也可实现相互切换

在上边代码中引入

from gevent.queue import Queue

引入猴子补丁

from gevent import monkey;monkey.patch_all()#  猴子补丁
#  生产者与消费者

import gevent
from gevent import monkey;monkey.patch_all() # 猴子补丁
import random
from queue import Queue # 队列
q = Queue(2) def con(): # 消费者
while True:
print(q.qsize())
iten = q.get()
print('删除一个数据{}'.format(iten)) def pro(): # 生产者
while True:
print(q.qsize())
iten = random.randint(0,99)
q.put(iten)
print('添加一个数据{}'.format(iten)) p1 = gevent.spawn(pro)
c1 = gevent.spawn(con)
gevent.joinall([p1,c1])

  

0
添加一个数据57
1
添加一个数据25
2
2
删除一个数据57
1
删除一个数据25
0

协程,猴子补丁,实现并发服务器

from gevent import monkey;monkey.patch_all()
import socket
import gevent sever = socket.socket()
sever.bind(('',10000))
sever.listen(5)
print('服务器开启') def func(conn):
while True:
data = conn.recv(1024)
if data:
print(data)
else:break while True:
conn,addr = sever.accept()
print(addr)
gevent.spawn(func,conn)

  

潭州课堂25班:Ph201805201 并发(协程) 第十五课 (课堂笔记)的更多相关文章

  1. 潭州课堂25班:Ph201805201 并发(通信) 第十三课 (课堂笔记)

    from multiprocessing import Process # 有个 url 列表 ,有5个 url ,一次请求是1秒,5个5秒 # 要求1秒把 url 请求完, a = [] # 在进程 ...

  2. 潭州课堂25班:Ph201805201 django 项目 第四十五课 mysql集群和负载均衡(课堂笔记)

    2.使用docker安装Haproxy 一.为什么要使用数据库集群和负载均衡? 1.高可用 2.高并发 3.高性能 二.mysql数据库集群方式 三.使用docker安装PXC 1.拉取PXC镜像 d ...

  3. 潭州课堂25班:Ph201805201 django 项目 第三十五课 后台用户权限的添加 mixins 课堂笔记)

    验证用户登录: 对一个视图函数进行登录权限验证,(登录后才可以访问,否则重定向到登录页面) #from django.contrib.auth.decorators import login_requ ...

  4. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第四课 登录注册 (课堂笔记)

    index.html 首页 <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

  5. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第三课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  6. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第二课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  7. 潭州课堂25班:Ph201805201 WEB 之 页面编写 第一课 (课堂笔记)

    index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&quo ...

  8. 潭州课堂25班:Ph201805201 第十课 类的定义,属性和方法 (课堂笔记)

    类的定义 共同属性,特征,方法者,可分为一类,并以名命之 class Abc: # class 定义类, 后面接类名 ( 规则 首字母大写 ) cls_name = '这个类的名字是Abc' # 在类 ...

  9. python 并发协程

    一 引子 本节的主题是基于单线程来实现并发,即只用一个主线程(很明显可利用的cpu只有一个)情况下实现并发,为此我们需要先回顾下并发的本质:切换+保存状态 cpu正在运行一个任务,会在两种情况下切走去 ...

随机推荐

  1. opencv入门指南(转载)

    转载链接:http://blog.csdn.net/morewindows/article/details/8426318 网上的总结的一些用openncv的库来做的事: 下面列出OpenCV入门指南 ...

  2. classfication中使用图像金字塔和sliding windows提高准确率

    之前对imagenet的预训模型进行finetune,找出了很多样本选择时的注意事项,当时在测试如下这张照片时,效果不好,我认为是物体过小造成的,因此尝试使用图像金字塔的方法: 当时结果如下: 一开始 ...

  3. ARMV8 datasheet学习笔记4:AArch64系统级体系结构之编程模型(2)- 寄存器

    1. 前言 2. 指令运行与异常处理寄存器 ARM体系结构的寄存器分为两类: (1)系统控制和状态报告寄存器 (2)指令处理寄存器,如累加.异常处理 本部分将主要介绍如上第(2)部分的寄存器,分为AA ...

  4. register 用法注意与深入--【sky原创】

    register 用法注意与深入:   gcc -o test  test.c   这样编译的话会报错的,因为寄存器变量是不能取地址的,只有内存的变量才能取地址 寄存器变量取的是虚拟地址   #inc ...

  5. php 日期格式转换万能公式

    思路用strtotime转换时间的字符串 $t='2017-03-09 02:30'; echo(date('Y-m-d H-i', strtotime($t)));

  6. linux 平台core dump文件生成

    1. 在终端中输入ulimit -c 如果结果为0,说明当程序崩溃时,系统并不能生成core dump. root@hbg:/# ulimit -c0root@hbg:/# 2.使用ulimit -c ...

  7. centos6中创建软raid方法

    raid概述: 组建raid阵列命令: mdadm:模式化的工具 /etc/mdadm.conf     -A  Assemble 装配模式     -C  Create 创建模式     -C:专用 ...

  8. 重装windows系统后配置Anaconda

    给电脑换了系统,十分担心anaconda需要重装.还好以下方法完美解决.(同是win10 64位) 原始anaconda安装路径:D:\ProgramData\Anaconda3  (不能有空格哦) ...

  9. mac安装RabbitMQ

    1 下载 地址 http://www.rabbitmq.com/install-standalone-mac.html 2 rabbitmq的安装目录: /Users/ysyc1/rabbitmq_s ...

  10. idea开发swing(二)

    闲话少说,书接idea开发swing(一). 程序编译完成后,需要打包发布,如果有fat_jar的同学可以通过该插件打包,这里是使用ant来打包,步骤如下: 一.编写build.xml <?xm ...