当前位置:
首页 > temp > 简明python教程 >
-
python基础(35):协程(3)
import threading
import gevent
import time
def eat():
print(threading.current_thread().getName())
print('eat food 1')
time.sleep(2)
print('eat food 2')
def play():
print(threading.current_thread().getName())
print('play 1')
time.sleep(1)
print('play 2')
g1=gevent.spawn(eat)
g2=gevent.spawn(play)
gevent.joinall([g1,g2])
print('主')
回到顶部(go to top)
5. Gevent的同步和异步
- from gevent import spawn,joinall,monkey;monkey.patch_all()
- import time
- def task(pid):
- """
- Some non-deterministic task
- """
- time.sleep(0.5)
- print('Task %s done' % pid)
- def synchronous(): # 同步
- for i in range(10):
- task(i)
- def asynchronous(): # 异步
- g_l=[spawn(task,i) for i in range(10)]
- joinall(g_l)
- print('DONE')
- if __name__ == '__main__':
- print('Synchronous:')
- synchronous()
- print('Asynchronous:')
- asynchronous()
- # 上面程序的重要部分是将task函数封装到Greenlet内部线程的gevent.spawn。
- # 初始化的greenlet列表存放在数组threads中,此数组被传给gevent.joinall 函数,
- # 后者阻塞当前流程,并执行所有给定的greenlet任务。执行流程只会在 所有greenlet执行完后才会继续向下走。
回到顶部(go to top)
6. Gevent之应用举例
通过gevent实现单线程下的socket并发
注意 :from gevent import monkey;monkey.patch_all()一定要放到导入socket模块之前,否则gevent无法识别socket的阻塞。
server:
- from gevent import monkey;monkey.patch_all()
- from socket import *
- import gevent
- #如果不想用money.patch_all()打补丁,可以用gevent自带的socket
- # from gevent import socket
- # s=socket.socket()
- def server(server_ip,port):
- s=socket(AF_INET,SOCK_STREAM)
- s.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
- s.bind((server_ip,port))
- s.listen(5)
- while True:
- conn,addr=s.accept()
- gevent.spawn(talk,conn,addr)
- def talk(conn,addr):
- try:
- while True:
- res=conn.recv(1024)
- print('client %s:%s msg: %s' %(addr[0],addr[1],res))
- conn.send(res.upper())
- except Exception as e:
- print(e)
- finally:
- conn.close()
- if __name__ == '__main__':
- server('127.0.0.1',8080)
client:
- from socket import *
- client=socket(AF_INET,SOCK_STREAM)
- client.connect(('127.0.0.1',8080))
- while True:
- msg=input('>>: ').strip()
- if not msg
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数