专访开源项目Amoeba架构师陈思儒
DBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。
作者 Jonathan Allen译者 陈黎夫 发布于 2007年7月5日 下午7时35分
在《LINQ Cookbook》的第5个条目(拼接CheckedListBox中选中的字符串)中,微软公司Visual Basic团队演示了分别使用两种VB 9中的新特性来实现这类字符串连接的方法。
在第一种方法里,Visual Basic团队使用了LINQ的聚合(Aggregate)语法。如下述代码所示,将各个字符串用逗号连接起来:
MsgBox( _
Aggregate Box In CheckedListBox1.CheckedItems _
Into Concat())
代码中的Concat是一个扩展方法(extension method),其实现如下:
Public Module AggregateModule
Public Function Concat(Of Type)( _
ByVal ie As IEnumerable(Of Type)) As String
Dim str As String = ""
For Each item In ie
If str <> "" Then str &= ","
str &= item.ToString()
Next
Return str
End Function
End Module
若不想如此麻烦地额外编写一个扩展方法,C#和VB开发者也可以使用Lambda表达式来完成同样的功能。其语法略显复杂,不过也还可以接受:
MsgBox((From c In _
CheckedListBox1.CheckedItems).Aggregate( _
Function(ByVal x, ByVal y) x + "," + y))
不过,Bill McCarthy却指出,这种方法存在着一些问题,包括性能方面:
若是通过编写扩展方法来完成的话,我们可以借助StringBuilder来提高字符串拼接的效率,不过若是使用lambda表达式,那么又该如何使用 StringBuilder呢?若是我们无法找到可行的解决办法,那么使用lambda表达式势必将在每次字符串连接的时候都要创建若干个不必要的对象副 本——我们都知道在.NET中,这是拼接字符串操作的大忌。而在编写扩展方法时,我们则可以很容易地通过重构来引入高效的StringBuilder对象。
另外一个让Bill McCarthy担心的问题就是,lambdas表达式的方式无法提供良好的可重用性。lambdas表达式通常在某个函数的上下文中出现,并在函数结束 时被销毁,因此除非将其作为委托返回,否则很难实现重用。不过对于只支持单行lambdas表达式的VB来说,这不会产生太大的问题,但对于支持较长 lambdas表达式的C#来说,也许会出现一定问题。
查看英文原文:Performance Problems with LambdasDBA notes站长冯大辉(Fenng)代表InfoQ中文站采访了分布式数据库Proxy开源项目Amoeba的架构师和主要开发者陈思儒,内容包括Amoeba项目的起因、功能及其愿景等。
作为三期系列文章的第二部分,本文延续了上一期内容,介绍了RichFaces,包括如何把RichFaces集成到之前提到的示例应用中、如何部署RichFaces porlet和RichFaces的多种特性和功能。
Amazon Web Services(AWS)的传道者Jeff Barr讨论了SimpleDB、S3、EC2、SQS、云计算、Amazon的不同服务如何与应用交互、AWS的起源、SimpleDB和微软SQL Server Data Services、AWS cloud的全球化、三月份的AWS停机。
Erlang的并发模型很有名,它的健壮性也很有名。但其他方面呢?在这篇文章里,Dennis Byrne演示了如何用Erlang建立内部DSL。
本视频主要以FreeWheel为例,对一个基于Rails的企业级应用进行了剖析。其中包括:FreeWheel的架构、部署、数据库的问题、REST API、敏捷开发过程、如何去写测试以及持续集成等等。
JavaFX显示了Sun的Java系列产品市场方向的一个重大转变。随着1.0版的即将发布,InfoQ以JavaFX预览版为参考,与Sun高级工程师Joshua Marinacci探讨了即将发布的1.0正式版。
本文主要讲述了如何用JBoss Portlet Container 和JBoss Portlet Bridge创建新项目,怎样配置一个JSF应用去使用JBoss Portlet Bridge,以及JBoss Portlet Bridge所具备的功能。
没有回复
回复