模块化Java:声明式模块化
本文是模块化Java系列文章的第4篇,介绍的是声明式模块化。文中描述了组件如何以声明的方式来定义并组织在一起,而无需让代码依赖于OSGI API。
作者 Sam Aaron 译者 仝键 发布于 2007年9月17日 下午7时30分
这篇文章是介绍Ruby x Agile系列的第二篇,该系列文章记录了一套包含六个简短视频,视频探讨Ruby和敏捷方法论之间的关系。我们第一篇文章的内容是为什么Ruby和敏捷是一个好的组合。
这些视频的主要内容是Ruby的创始人松本行弘(Matsumoto, Yukihiro,昵称Matz,株式会社网络应用通信研究所[NaCl]的特别研究员)、自以为“敏捷煽动者(Agile agitator)”的平锅健儿(Hiranabe, Kenji,Change Vision公司的CEO)和Ruby的支持者角谷信太郎(Kakutani, Shintaroh,永和系统管理株式会社服务提供部的程序员[Service Providing Div. Programming, Eiwa System Management, Inc.])之间的一场讨论。
该系列的这一部分以一场关于关注焦点从对CPU效率进行优化到对程序员效率进行优化转变的讨论开始。
“以前,CPU时间确实是宝贵的,但是现在人们的时间更宝贵,而且关注点已经转变到让人们从事的工作更加容易了。”
他们讨论了社会对IT依赖的增长和相关的程序开发成本之间的关系,并得出这样的结论:使用人力去节省CPU时间的观念将变得非常奢侈,而且解决方案并不是增加程序员数量,而是使用更好的工具和实践:
“如果我们转变关注点,并且在(计算的)和人相关的一面着手工作,将不需要这么多的程序员。我觉得,这个概念在诸如XP/敏捷或者Rails这样的运动中被体现了出来。”
“从机器效率向人的效率进行的转变已经产生。”
但是,Matz认为目前在CPU效率应被优先考虑的仅存领域就是超级计算(super-computing)。
视频最后以关于传统软件开发和敏捷软件开发所引入的过程之间区别的讨论收尾。三人介绍到,包含市场调研、下订单、交付和发布的传统工作流迭代(如第一图所示)需要花费一个季度到三年的时间才能完成。他们认为,如果将这些工作流单位的同步序列分解成更小的异步块的话(如第二图的内循环所示),那么可能能在一周到三个月内完成一次迭代。
“这么一个周期要花费一个季度到一年或者更多,也许甚至能达到三年之久。”
“当我们从这个模型(图一)转换到这个模型(图二),那这就是敏捷了。达到这一步的关键是语言的力量、业务和过程的同步或者匹配。”
当要求他解释“内循环(inner loop)”的含义时,平锅用下面的回答剖析到:
您可以观看该系列相应的视频来了解更多的内容。这些视频的语言是日语,配有相应的英文字幕。
查看英文原文:Ruby x Agile: The shift from machine-performance to human-performance本采访是在伦敦举行的QCon2009上记录的,Ian Robinson和Jim Webber探讨了如何将Web作为整合平台以及REST在理论上和实践中的好处。
项目管理对于项目成败至关重要,但实践中每个项目都有自己的独特性,没有现成的解决方案可以套用。书中从应对实际风险的角度出发,讲述了从项目启动、项目规划到项目结束的整个管理流程,展示了作者的思考过程。本迷你书从原书中精选出5个章节。
在这个演讲中,Fred将会揭示敏捷的一些外在因素,并会重点关注敏捷获得成功的内在原因。从案例研究和真实的项目经验来看,Fred认为:工具、管理体系都不能让你变得敏捷。敏捷的成功,植根于士气高涨、充分授权的工作者身上,他们能够以不同以往的方式思考问题。
Eben Hewitt的新书《Java SOA Cookbook》从Java实现的角度讨论了面向服务架构。Eben在书中讨论了SOA基础、工具、最佳实践和SOA治理等主题。
Mark Richards的新书《Java消息服务》第二版覆盖了JMS的许多主题, 包括发布和订阅模式以及点对点模式,消息过滤和事务等。InfoQ与Mark谈论了跟他的新作。
没有回复
关注此讨论 回复