剖析短迭代
敏捷教练Dave Nicolette提出:我们应该如何设定迭代长度?是要根据发布周期的时间么?使用短迭代又有哪些好处?
作者 R.J. Lorimer译者 张龙 发布于 2008年5月28日 上午8时30分
正如John Rose所宣称的那样,在JavaOne会议结束不久,JSR-292草案紧接着发布了。JSR-292用来为Java虚拟机定义invokedynamic指令规范。
InfoQ在去年十月份Da Vinci虚拟机项目(MLVM)发布的时候曾报道过JSR-292,该项目是对invokedynamic这样的技术的试验台(test bed)。
JSR-292规范领导者和MLVM的主要支撑者John Rose在其博客上就JVM应更加亲近动态语言的问题进行了一些探讨。最近,Rose就提出JSR-292的缘由进行了一些说明:
为什么增加另一种调用字节码呢?答案就是调用地点(调用字节码的实例)是非常有用的,然而现存的调用规则与Java语言绑定的太紧了以致于JVM的很多能量并未对想依附其的语言释放出来。主要的限制如下:动态语言实现者在这些限制上花费了大量时间和精力,根据JVM调用字节码(由Java语言限制)模拟出一般的调用。
- 接收者(receiver)类型必须遵循调用地点的解析类型
- 并没有一般的方式以围绕着调用目标创建适配器(这是上述限制的必然结果)
- 调用地点必须要链接起来,这意味着调用前已解析的方法就要存在
- 符号调用名就是实际的方法名(这是上述限制的必然结果)
- 要有精确的参数匹配(又是一个必然结果)
- 不能颠倒链接结果(尽管优化结果在不知不觉中发生变化)
随后,他又阐述了JSR-292小组提出的解决方案:
我们用三个步骤解决这些问题。首先,我们以一种简单而一般的方式来处理方法句柄,这是将方法(任意的JVM方法)作为行为单元来管理的,这样他们就可以直接调用了(本来就应该这样)。其次,我们用一个链接状态的机器字定义一个invokedynamic指令,它是调用地点上目标方法的句柄。第三,我们定义一套核心的Java APIs以管理链接状态并为调用地点创建目标方法句柄。注意,他们这些APIs能向愿意使用其的JVMs提供恰当的优化机会。
草案的宣布也拉开了为期90天的JSR审查期的序幕,这将于2008年8月17日结束。只要在这期间,你就可以通过多种方式获取信息并就JSR有关问题提出反馈:
InfoQ将持续跟踪JSR-292的最新进展并在Java社区进行更新。
查看英文原文:JSR-292 Early Draft Review Announced
本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。
在这篇文章里,Bryon Jacob和Chris Berry将和我们继续探讨AtomServer,它是基于Apache Abdera的完整Atom存储实现。作者还创建了几个Atompub规范扩展,其中包括自动标记、批处理和Feeds聚合。
InfoQ中文站的电子杂志《架构师》试刊第二期出版了!相比于上期,我们在内容的选择安排和版式上都根据读者的意见重新做了修正。“细节决定成败”,我们希望基于InfoQ中文站的专业内容,《架构师》能逐渐成为大家喜欢的电子刊物!
在本文中,Steven Haines探讨了Web应用性能调优问题。该领域过去更像是一门艺术而不是一门科学。他提出了一种称为基于等待调优的方法,使整个调优过程更加可度量,也因此更具科学性。
通常来说,改变技术路线时最艰难的部分是辨别语言语法之间的不同。这篇文章就为Java开发者提供了一份如何转向Flex基础语言ActionScript的指南。
本视频主要以财帮子为例,介绍了如何创建一个PV为百万级的Rails应用。其中包括:Rails应用的服务器架构、Rails Cache的优化、负载均衡的处理、Web服务器的调试、分布式解决方案、Open API的设计等等。
InfoQ首席架构师Alexandru Popescu在采访中谈论了InfoQ架构、Webwork与DWR、Hibernate与JCR、Hibernate可扩展性、最新的InfoQ视频流系统和InfoQ的未来规划。
1 条回复
回复