InfoQ

新闻

为灵活性和健壮性而设计:异步消息模型、OOP和函数式编程

作者 Sadek Drobi译者 郭晓刚 发布于 2007年11月17日 上午11时41分

社区
Architecture
主题
设计,
消息传送,
性能和可伸缩性,
面向对象设计,
建模
标签
并行计算,
Erlang,
面向对象编程,
Haskell,
函数式编程

“吩咐,不要询问”:按照Pragmatic Programmers的说法,在面向对象编程中最好“吩咐一个对象让它去做些什么,而不是向它索要数据”。Michael Feathers认为“这是一个极佳的建议”,特别是对于比较大的系统:

返回值把工作又推回给调用者。单单做完一件事然后向协作者发送一条消息还不算完;你必须等着看有没有什么被送回来,然后可能还要做更多的事情。如果不返回值会让我们更轻松一点。

Feathers认为在测试驱动开发中使用Mocks会导致这种类型的架构:

与其吩咐一个对象去做事,然后询问它是否已经完成,你不如吩咐它去做事,然后看看它的协作者有什么变化。[……]这有点像工作流。[……]遇到新需求的时候比较不会影响到设计。而且,这样很合理。每个对象负责一件事情,并且通知下一个接班的对象。

我们还可以更进一步。Feathers主张如果没有返回值需要等候,那么发送“异步消息比同步消息更好“。实际上H.S. Lahman早就主张过在面向对象架构中的“行为是被假定为异步的”。如今的OOP模型是同步的,这是因为在面向对象编程语言中“没有区分开消息和方法”。因此“更加难以构造出正确的OOA/D模型”,正确的模型不仅可以显著提高可维护性,还包括健壮性。

Michael Feathers描述说这种做法也与Erlang的模型相吻合:

Erlang隐含的思想是,如果你能创建大量的进程,并保证它们绝不共享状态,你就可以开发出更加健壮的系统。每个进程接收消息,做自己的工作,然后向其他进程发送消息。消息的发送主要是异步的。

Feathers认为,“吩咐,不要询问”的编程模型“几乎是函数式编程的反面”,虽然“两者都有一个相对无状态的河床让数据从上流过”:

在最纯粹的函数式编程中,你从不吩咐,总是询问。而且如果有缓求值(lazy evaluation)帮忙,系统只需完成最必不可少的操作来回答你的问题。

不过可争议的是Erlang不能被认为是纯粹的函数式语言。Feathers也特别引用Ralph Johnson的观点,他指出Erlang的“核心里头是OO”。

就你的观点,哪种无状态模型最适合处理现今的适应性和健壮性问题呢?是Erlang的异步消息模型还是某种纯粹的函数式编程方法(如Haskell)?

查看英文原文:Designing for flexibility and robustness: Asynchronous message model, OOP and Functional Programming

3 条回复

回复

这个想法倒是很标新立异 发表人 fan fan 发表于 2007年11月19日 下午6时46分
Re: 这个想法倒是很标新立异 发表人 Jeffrey Zhao 发表于 2007年11月19日 下午10时16分
Re: 这个想法倒是很标新立异 发表人 东 黄 发表于 2007年11月20日 上午12时52分
  1. 返回顶部

    这个想法倒是很标新立异

    2007年11月19日 下午6时46分 发表人 fan fan

    unix有条原则:如果一个程序没有什么好说的,就保持沉默。
    返回值也是接口定义的一部分。

  2. 返回顶部

    Re: 这个想法倒是很标新立异

    2007年11月19日 下午10时16分 发表人 Jeffrey Zhao

    Tell, don't ask
    其实是很早以前就提出来的.

  3. 返回顶部

    Re: 这个想法倒是很标新立异

    2007年11月20日 上午12时52分 发表人 东 黄

    actionscript就是这样的,但是这样带来一个问题,你不断被你所发送消息的对象的通知所打扰,而且有些操作是必须要等待到返回值你才能继续的,还是要看什么样的情形来怎么样做。

独家内容

剖析短迭代

敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?

应用JSF、Ajax和Seam开发Portlets(1/3)

本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。

AtomServer:数据分发的发布动力(第二部分)

在这篇文章里,Bryon Jacob和Chris Berry将和我们继续探讨AtomServer,它是基于Apache Abdera的完整Atom存储实现。作者还创建了几个Atompub规范扩展,其中包括自动标记、批处理和Feeds聚合。

架构师(试刊第二期)

InfoQ中文站的电子杂志《架构师》试刊第二期出版了!相比于上期,我们在内容的选择安排和版式上都根据读者的意见重新做了修正。“细节决定成败”,我们希望基于InfoQ中文站的专业内容,《架构师》能逐渐成为大家喜欢的电子刊物!

一种正规的性能调优方法:基于等待的调优

在本文中,Steven Haines探讨了Web应用性能调优问题。该领域过去更像是一门艺术而不是一门科学。他提出了一种称为基于等待调优的方法,使整个调优过程更加可度量,也因此更具科学性。

Java程序员ActionScript 3入门

通常来说,改变技术路线时最艰难的部分是辨别语言语法之间的不同。这篇文章就为Java开发者提供了一份如何转向Flex基础语言ActionScript的指南。

浅谈如何创建Rails应用

本视频主要以财帮子为例,介绍了如何创建一个PV为百万级的Rails应用。其中包括:Rails应用的服务器架构、Rails Cache的优化、负载均衡的处理、Web服务器的调试、分布式解决方案、Open API的设计等等。

Alexandru Popescu谈InfoQ.com网站架构

InfoQ首席架构师Alexandru Popescu在采访中谈论了InfoQ架构、Webwork与DWR、Hibernate与JCR、Hibernate可扩展性、最新的InfoQ视频流系统和InfoQ的未来规划。