python 进程 线程 携程_进程、线程和携程的通俗解释【刘新宇Python】

通过下面这张图你就能看清楚了,进程、线程和携程的关系

进程:

多个进程是可以运行在多个CPU当中的,比如你的电脑是4核,可以同时并行运行四个进程,这是真正物理上的并行运行。

线程:

每个进程又可以有多个线程,线程是轮询执行的,因为轮询的速度很快,所以可以看成是并行。

微线程:

携程是微线程,一个线程可以分为多个携程,同样也是轮询执行,这样的好处是减少CPU的资源消耗,一些比较多而且小的事件可以用携程去处理,减少资源的开销。

协程原理

生成器器

def fun1():

print(100)

print(200)

yield # 暂停代码 保存断点状态

print(100)

print(100)

yield

eventlet

print(100)

print(100)

def fun2():

print(100)

print(200)

yield

print(100)

print(100)

yield

print(100)

print(100)

gen_obj1 = fun1() # 创建了生成器器对象

gen_obj2 = fun2()

next(gen_obj1)

next(gen_obj2)

next(gen_obj1)

next(gen_obj2)

通常采用协程库(扩展库)来完成协程开发

协程库能够自动帮助完成协程的执行切换

eventlet

from multiprocessing import Process

p = Processs()

p.start()

from threading import Thread

t = Thread()

t.start()

from eventlet import Eventlet

e1 = Eventlet()

e1.start()

e2 = Eventlet()

e2.start()

协程运行socketio服务器器的⽅方式

pip install eventlet

import eventlet

eventlet.monkey_patch()

import socketio

import eventlet.wsgi

# Server对象理理解为Flask⾥里里⾯面的应⽤用对象就可以

# sio对象是⽤用来管理理socketio即时通讯业务的

sio = socketio.Server(async_mode='eventlet') #

指明在evenlet模式下

app = socketio.Middleware(sio)

eventlet.wsgi.server(eventlet.listen(('',

8000)), app)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值