我们开始在项目中更多地使用GWT, GWT编译器的性能也越来越令人讨厌。
我们将开始改变我们的工作实践来缓解这个问题,包括更加强调托管模式浏览器,它将运行GWT编译器的需要推迟到以后,但这也带来了风险,特别是在真正的浏览器中发现问题的时间比我们希望的要晚得多。
理想情况下,我们希望让GWT编译器本身更快——编译一个相当小的应用程序只需一分钟,这简直是浪费时间。但是,我们使用的编译方式相当简单,所以我希望我们可以快速轻松地获得一些好处。
我们目前正在调用com.google.gwt.dev.Compiler作为一个java应用程序从ant ant目标,最大堆256m和大量的堆栈空间。编译器由Ant使用fork=true和最新的Java6 JRE启动,以尝试并利用Java6改进的性能。我们将主控制器类与应用程序类路径一起传递给编译器,然后就可以运行了。
我们还能做什么来获得额外的速度?我们能不能给它更多的信息,让它花更少的时间去发现该做什么?
我知道我们可以告诉它只编译一个浏览器,但我们需要做多浏览器测试,所以这是不实际的。
在这一点上欢迎任何建议。
让我们从一个令人不舒服的事实开始:GWT编译器的性能非常糟糕。您可以在这里或那里使用一些技巧,但不会获得明显的性能提升。
你可以做的一个很好的性能hack是只编译特定的浏览器,通过在你的gwt.xml中插入以下行:
<define-property name="user.agent" values="ie6,gecko,gecko1_8"></define-property>
或者在GWT 2。X语法,并且仅适用于一种浏览器:
<set-property name="user.agent" value="gecko1_8"/>
例如,这将只编译IE和FF的应用程序。如果您知道您只使用特定的浏览器进行测试,您可以使用这个小技巧。
另一种选择:如果您正在使用多个语言环境,并且同样只使用一个语言环境进行测试,您可以将它们全部注释掉,这样GWT将使用默认的语言环境,这将在编译时减少一些额外的开销。
底线:编译器的性能不会得到数量级的提升,但是通过一些放松,您可以在这里或那里节省几分钟的时间。
GWT编译器要做大量的代码分析,因此很难加快它的速度。谷歌IO 2008的这节课将让您很好地了解GWT在做什么,以及为什么它需要这么长时间。
我的建议是开发时尽量使用托管模式,然后只在你想进行测试时进行编译。这听起来确实像您已经得到的解决方案,但基本上这就是为什么有托管模式(好吧,这和调试)。
您可以加快GWT的编译速度,但只针对某些浏览器,而不是GWT默认的5种浏览器。如果你想使用托管模式,确保你至少编译了两个浏览器;如果你为单个浏览器编译,那么浏览器检测代码就会被优化,然后托管模式就不再工作了。
为较少的浏览器配置编译的一个简单方法是创建第二个模块,它继承自你的主模块:
<module rename-to="myproject">
<inherits name="com.mycompany.MyProject"/>
<!-- Compile for IE and Chrome -->
<!-- If you compile for only one browser, the browser detection javascript
is optimised away and then Hosted Mode doesn't work -->
<set-property name="user.agent" value="ie6,safari"/>
</module>
如果将rename-to属性设置为相同,则输出文件将与进行完整编译时相同