Python网络编程Twisted框架学习(一)、Twisted理论基础

  Python有四大主流网络编程框架,Django、Tornado、Flask、Twisted。关于每种框架的介绍,可以自行搜索。

  Django更适合Web方面,Twisted更适合网络服务器。 Twisted是基于事件的一个框架,以reactor为一个大循环,收到事件根据事件状态再跳转执行某个对应的函数。主要有Protocol,Factory,Transport,Reactor几个部分。另外初学者可能经常见到Derfered,这是Twisted加进去的,有了derfered可以轻松的完成函数回调(所谓回调,就是某个事件发生了,我调用相应的函数)。

  用白话来讲,就是我收到了什么,所以我要干什么。以简单的tcp通信为例,我收到了信息,该框架自动调用连接后处理的代码。连接后出现了错误,自动调用出现错误的代码,并且中止循环。

  Twisted是异步的,单线程。
单线程包括同步和异步,简单来说,我们把一个进程分成多个任务,这些任务互斥执行,如下三个任务的执行:

Python网络编程Twisted框架学习(一)、Twisted理论基础_第1张图片
同步模型,一个任务执行完才能执行下一个任务。

Python网络编程Twisted框架学习(一)、Twisted理论基础_第2张图片
异步模型,微观上交替执行。
Twisted异步,如果把函数看成任务,这个函数没执行完,会主动放弃CPU控制权转让给别的任务。

下面是这几天学习Twisted的一些资源:

https://blog.csdn.net/bluehawksky/article/details/79814577有关于回调的一些图解

http://blog.sina.com.cn/s/blog_704b6af70100py9n.html twisted书籍章节,基于github的一个诗歌项目

https://www.cnblogs.com/zhangjing0502/archive/2012/05/17/2506687.html
对protrocl,factory,reactor的讲解非常详细

http://blog.sina.com.cn/s/blog_704b6af70100py9n.html六十多页百度文库最详细的讲解,由浅入深

你可能感兴趣的:(网络编程)