技术开发 频道

Swing是一把刀 虽然原始却依然锋利

  【IT168 评论】对Swing的抱怨和批评从来就没有停止过。不过从以前的铺天盖地,到后来的见怪不怪,到现在的冷冷清清。似乎人们早就已经浸淫在无处不在的web和满天飞的RIA之中,懒得去理会Swing这个老古董了。难道Swing真的到了日薄西山、穷途末路的地步?

  大家对待Swing的态度从来就不缺乏偏见。作为Java的桌面UI技术,其实它和MFC、VCL、Winform、WPF以及Flex、Silverlight一样,只是做界面的技术工具而已,本身并没有什么不好。只要计算机还用屏幕、键盘、鼠标来进行交互,这些UI技术(或其后续改良继任者)就会始终存在。无论哪个UI技术,说到底都是在屏幕上画图,本质上都是画点、划线而已,只是有的用起来复杂,有的简单,有的功能强,有的功能弱。不过对于技艺高超者来说,给个邮票大的地方也能跳出激动人心的舞蹈,Flex不就是在Flash这块邮票上面不停的折腾么?这又和脚下的空间有多少关系呢?相比Flash/Flex这张小邮票,Swing则给了我们一个巨大的足球场。如果我们还是不能在这个舞台上吸引更多的观众,还是多反思一下自己的舞技吧,就算脚下的场地有点湿滑不平,我们也没必要喋喋不休。

  Swing的设计的确有点过于概念化,导致结构比较抽象,对初学者来说确实比较费劲。记得最开始学习Swing时,弄个table还要创建什么TableModel,还有个AbstractTableModel,还有个DefaultTableModel…一头雾水。为什么不是table.addRow(String[] row)就ok么?直到慢慢理解了MVC,理解了更多设计模式,理解了action和listener监听,renderer/editor机制,UI代理、事件派发线程…才慢慢理解和掌握了Swing,编程水平也有了很大提高。而回头再看十年前用VB6写程序,DIM一个ADO、连接ODBC、拖拽一个文本框、设置属性绑定….简直就是工具的奴隶,一点软件设计的内涵也没学到,不客气的说真是害了一代人。

  人类能发展在于善用工具。要把各种UI技术比喻成工具刀,Swing是哪类刀呢?有人说Swing连个TreeTable、日期控件都没有,真是原始社会(夸张点吧,怎么也算封建社会吧)!那么Swing就是这样一把刀了?

  这把刀实在是吓坏了不少人。不过一些痛恨Swing的人会觉得很解气。要说有偏见吧,确实偏见是无处不在的。就像美国人鄙视日本人,日本人鄙视韩国人,韩国人鄙视中国人,中国上海人鄙视北京人,北京人鄙视天津人,天津人鄙视河南人,河南人鄙视新疆人,新疆人鄙视所有人…………..扯远了。其实熟悉一段时间Swing后,只要掌握了一些基本的MVC设计思路和常用组件的使用方法,就会发现,这把刀可以很锋利,可以说是“宝刀未老”,而不是“锈迹斑斑”:

  不过对于很多非常简单的UI任务来说,Swing会显得很啰嗦、很繁琐。API浩如烟海,文档缺乏,一头扎进去半天出不来。我们头大,我们发狂:我要拧一个螺丝而已,你却给我下面这把刀:

  所以,你家里需要准备一个单独的螺丝刀,用来拧螺丝;准备一把剪刀,用来剪纸张;一个刮胡刀,用来刮胡子;一把菜刀,用来切菜;还要一个指甲刀,用来剪指甲。虽然菜刀也能凑合割指甲,刮胡刀剁饺子馅也没意见(疯了),但是你显然不想这么做。所以,别抱怨Flex这把剪刀功能不够强,Silverlight这个螺丝刀功能不够多,Swing太复杂。作为Java平台的厂商,Sun除了推出Swing这样的全功能工具刀,还能如何呢?现实世界需求很复杂,只能尽量全满足。这就是生活。

  所以,上战场除了带上冲锋枪,扛上火箭筒的同时,挎上GPS,腿上还要再绑上一把刀。程序员也是一样,多一项技能就是多一项武器,关键时刻一个都不能少,一个武器就多一个生存的机会。

0
相关文章