###############    协程介绍    ##############

"""
协程介绍 # 协程和进程和线程一样都是实现并发的手段, # 协程
# 协程本质上是一个线程,
# 什么是协程:能够在多个任务之间切换来节省一些IO时间,
# 不需要再浪费线程之间的切换了,只需要做程序之间的切换,
# 程序任务之间的切换也是需要消耗时间,但是开销远远小于进程线程之间的切换, 进程是操作系统调度的,
线程是cpu调度的最小的单位
协程本质就是一个线程,就是在线程上面来回切换而已, 进程和线程之间的切换是由操作系统完成,
协程任务之间的切换是由代码完成的, 对比操作系统控制线程的切换,用户在单线程内控制协程的切换
优点如下:
#1. 协程的切换开销更小,属于程序级别的切换,操作系统完全感知不到,因而更加轻量级
#2. 单线程内就可以实现并发的效果,最大限度地利用cpu
缺点如下:
#1. 协程的本质是单线程下,无法利用多核,可以是一个程序开启多个进程,每个进程内开启多个线程,每个线程内开启协程
#2. 协程指的是单个线程,因而一旦协程出现阻塞,将会阻塞整个线程 # 协程:
# c和c++,没有协程的概念,但是python有,
# 这个协程,比线程,进程更加的简单,使用的时候是非常简单的,但是想要明白协程的这个过程,是比较复杂的,
# 使用gevent来实现协程,想要明白gevent就要明白greenlet,想要明白greenlet就要明白yield,
想要明白yield就要明白生成器,想要明白生成器,就要明白迭代器, """

 ###############    协程介绍    ##############

# from greenlet import greenlet
# # 这个模块可以实现协程的多个任务的切换,
# # 这个greenlet就是真正的协程模块,
#
# def eat():
# print("eat start")
# g2.switch()
# print("eat end")
#
#
# def play():
# print("play start")
# g1.switch()
# print("play end")
#
#
# g1 = greenlet(eat) # 注册,
# g2 = greenlet(play)
# g1.switch() # 切换
# g2.switch() """
eat start
play start
eat end
play end
这就是实现了协程之间的切换 """ # 我们在工作中会使用进程,线程,协程来提高代码的并发效果,
# 最多可以启动500个协程
# 假设是4核cpu,
# 可以开5个进程,20个线程,500个协程,就是5万个,就是允许5万个并发

 ###############    协程介绍    ##############

from gevent import monkey;

monkey.patch_all()  # 引入了这个就可以识别time.sleep了,这个必须写到最上面,
import gevent
import time def eat():
print("eat start")
time.sleep(1)
print("eat end") def play():
print("play start")
time.sleep(1)
print("play end") g1 = gevent.spawn(eat) # 开启
g2 = gevent.spawn(play) g1.join()
g2.join() """
你使用的时候,只需要把你的函数代码注册一下,然后就不需要管了,
遇到IO了之后,会自动切换到另外一个任务去执行,然后再次回来,
这样利用IO的时间,进入了IO(time.sleep(1))了之后不会停下来,会切换到其他的任务,然后第一个任务IO之后就切换回来,继续执行,
协程的切换就是gevent来实现的, """

 ###############    协程介绍    ##############

python语法基础-并发编程-协程-长期维护的更多相关文章

  1. python语法基础-并发编程-进程-进程理论和进程的开启

    ############################################## """ 并发编程的相关概念: 进程 1,运行中的程序,就是进程,程序是没有生 ...

  2. python语法基础-并发编程-进程-进程锁和进程间通信

    ###############   守护进程  ############## """ 守护进程 父进程中将一个子进程设置为守护进程,那么这个子进程会随着主进程的结束而结束 ...

  3. python语法基础-并发编程-线程-长期维护

    ###############   线程和GIL,全局解释器锁    ############## """ 线程 为什么会有进程? 主要是能够同时处理多个任务,多个任务还 ...

  4. python语法基础-并发编程-线程-线程理论和线程的启动

    #######################       线程介绍         ############################## """ 线程介绍 为什 ...

  5. python语法基础-并发编程-进程-进程池以及回调函数

    ###############   进程池    ############## """ 进程池的概念 为什么会有进程池? 1,因为每次开启一个进程,都需要创建一个内存空间 ...

  6. python语法基础-并发编程-进程-其他

    ###############    多进程的信号量    ############## # 多进程的信号量 from multiprocessing import Process import ti ...

  7. python语法基础-函数-迭代器和生成器-长期维护

    ###############    迭代器    ############## """ 迭代器 这是一个新的知识点 我们学习过的可以迭代的对象有哪些? list str ...

  8. python 并发编程 协程 目录

    python 并发编程 协程 协程介绍 python 并发编程 协程 greenlet模块 python 并发编程 协程 gevent模块 python 并发编程 基于gevent模块实现并发的套接字 ...

  9. 并发编程协程(Coroutine)之Gevent

    并发编程协程之Gevent Gevent官网文档地址:http://www.gevent.org/contents.html 基本概念 我们通常所说的协程Coroutine其实是corporate r ...

随机推荐

  1. lambda的题

    def num(): return [lambda x: i*x for i in range(4)] print([m(2) for m in num()]) 这个式子,lambda相当于闭包函数, ...

  2. FFmpeg命令大全(更新中)

    1.视频抽取音频: ffmpeg -i 3.mp4 -vn -y -acodec copy 3.aacffmpeg -i 3.mp4 -vn -y -acodec copy 3.m4a

  3. Python调用OpenCV读显写

    OpenCV提供了python的接口,而且很重要的一点是python下的很多接口名与C++的接口名是一样的,这一篇先记录python调用OpenCV去读取图像.显示图像和保存图像. 1.OpenCV读 ...

  4. js冒泡,阻止冒泡

    js 冒泡事件 阻止冒泡 window.onload = function () { var oDiv1 = document.getElementById('div1'); var oDiv2 = ...

  5. golang实现单链表

    package main import "fmt" type Object interface{} type Node struct { data Object next *Nod ...

  6. windows server 2012 ftp搭建

    1.安装IIS的时候勾选ftp 2.创建ftp站点,先检查21端口是否开放 一定要勾选身份认证,匿名去掉,不然一直登陆不了,也不提示 一直点下一步, 遇到的坑,第一个:出现“打开ftp服务器上的文件夹 ...

  7. MySQL优化查询相关

    [查询优化相关] 1.如何定位相关慢的查询: a.可以开启慢查询日志,也可以使用show profiles 去记录相关查询到一个临时表再分析. b.show processlist  看看有没有大量等 ...

  8. UML-活动图及其建模

    1.目标:UML活动图标示法. 2.定义:一个UML活动图标示一个过程中的多个顺序活动和并行活动.这些活动有助于对业务过程.工作流.数据流和复杂算法进行建模. 3.作用:既能表示控制流又能标示数据流. ...

  9. [CISCN2019 华北赛区 Day2 Web1]Hack World

    知识点:题目已经告知列名和表明为flag,接下来利用ascii和substr函数即可进行bool盲注 eg: id=(ascii(substr((select(flag)from(flag)),1,1 ...

  10. Dynamics CRM - 如何创建一个新的 Organization

    最近需要新建几个 CRM 的场来测试或者开发,也就是要新建 Organization,但是每次我都忘了在哪操作,写篇 blog mark 一下. 首先,新建 Organization 当然是要在 CR ...