摘要:点的话会提交一个请求给服务器,服务器返回一个新页面,其上面显示一个。对象的值是以协程的方式保存在服务器端的。类似的想法最出名的框架是的。于是乎就有这些诡异的实现了。
在史前的web开发时代(我说的是AngularJS工程师开始变得价值不菲之前的黑暗岁月),web开发的一个痛点在于HTTP是一个无状态的协议,浏览器是一个无状态的展示表单提交工具。当然现在的web开发世界已经不再是如此了,浏览器已经俨然是一个全功能的客户端了,B/S和C/S架构的差异已经接近弥合。在那个年代,有一些人就想,让状态从服务器传到浏览器,然后再在浏览器提交表单的时候传回来这多麻烦呀。如果能够让服务器保存表单状态,代码写起来该多么酷啊,比如下面这个例子(Stackless Python Nagare):
class Counter(object): def __init__(self): self.val = 0 def increase(self): self.val += 1 def decrease(self): self.val -= 1 @presentation.render_for(Counter) def render(counter, h, *args): h << h.div("Value: ", counter.val) h << h.a("++").action(counter.increase) h << "|" h << h.a("--").action(counter.decrease) return h.root
这段代码实现的功能是在浏览器上显示一个“0”,然后有++和--两个链接。点++的话会提交一个HTTP请求给服务器,服务器返回一个新页面,其上面显示一个“1”。
背后的思想是把页面上的内容建模为一个状态,在代码中这个状态就是那个counter对象。counter对象的值是以协程的方式保存在服务器端的。不仅仅是counter的值,以及h.a("++").action(counter.increase)这样绑定的事件与回调函数的映射也被保存了下来了。客户端的操作通过HTTP发到服务器之后。服务器根据渲染页面时注入的一些id表示符,找到对应的协程,然后加载协程,再把协程往后执行一步,同时渲染出一个新的HTML页面,返回给客户端。类似的想法最出名的框架是smalltalk的seaside。
假设我们是服务器,当我们把页面发给客户端之后,等待客户端的返回,然后根据返回执行后面的事情。类似这样
page1 = initial_render() send_to_browser(page1) resp = wait_for_browser_response() page2 = do_something(resp) send_to_browser(page2)
中间wait_for_browser_response()就是一个大大的流程阻塞,当然为什么不能用协程去对这个流程阻塞问题进行建模呢。于是乎就有这些诡异的实现了。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/45299.html
摘要:一般的做法是把这些动作写在和的两个方法里,单元测试框架会负责在开始和结束的时候调用这两个方法。从视觉上无法直观的指导原来和是一对的。然后再把这个小的上下文附着到主测试逻辑上这里利用了单元测试的的特性,把转化为回调在的时候就设置好。 很多测试都需要在启动的时候做一些事情,然后在结束的时候再把做的事情给清理了。一般的做法是把这些动作写在setUp和tearDown的两个方法里,单元测试框架...
摘要:常规版本的的是不可以被持久化保存的。在流程被阻塞的时候比如需要审批老板不在把协程持久化成入库,等流程不再阻塞的时候把协程重新从数据库里拉起来继续执行。 常规版本的Python的generator是不可以被持久化保存的。但是stackless和pypy这两个修改版本的Python解释器可以。下面这段代码演示了如何把一个执行中的函数持久化保存,然后过段时间再把函数从上次执行到的地方原样拉起...
摘要:所以我们这里谈的流程阻塞只是一种简化的流程建模的实现。在某种意义下,阻塞和流程阻塞都是阻塞问题。 咱不咬文嚼字地掰什么是Blocking I/O,什么是Async I/O,没啥意思。代码是用来解决问题的。有的时候透彻理解问题,会比透彻理解某个具体的解法更重要。 I/O阻塞的问题来源就是,当我们需要输入输出的时候,特别是通过网络传输数据的时候。从请求发出,到得到对方的应答确认是一段时间的...
摘要:标准的异常处理是这样的这段代码会打印出而不会打印出,因为异常会中断当前流程,跳转到部分去继续执行。这种行为类似里的。如何实现的其实原理上很简单。的时候把当前协程的状态保存起来,如果决定要,就把协程的时刻的状态重新恢复然后从那个点继续执行。 标准的异常处理是这样的 try: print(hello) raise Exception() print(!!!) ex...
摘要:另载于是个很爽的东西,线程安全,能当全局变量来用别。第一家公司,使用框架老技术,现代人可以理解为类似,对每个请求都套上,进入时把写入,返回或抛注意时清理。第二家公司,某次引入一个设计,也用了来传递上下文信息,有的地方没能清掉。 另载于 http://www.qingjingjie.com/blogs/12 ThreadLocal是个很爽的东西,线程安全,能当全局变量来用(别!)。 上一...
阅读 3618·2021-11-22 09:34
阅读 3188·2021-11-15 11:38
阅读 3045·2021-10-27 14:16
阅读 1237·2021-10-18 13:35
阅读 2426·2021-09-30 09:48
阅读 3430·2021-09-29 09:34
阅读 1635·2019-08-30 15:54
阅读 1821·2019-08-26 11:57