NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

文章:RichClient/RIA 原则与实践(上)

  • 2009-03-16
  • 本文字数:1326 字

    阅读完需:约 4 分钟

Web 领域的经验在过去十多年的不断的 使用和锤炼中,整个开发领域的技术、理念、缺陷已经趋于成熟,它丰富的积累使得开发者逐渐将更多的精力投入到应用本身。但是,目前仍然没有比较深入的实践 性文章来介绍企业环境下 RichClient 开发,而只是偏向于小规模特性介绍,但在大规模的企业应用中,这些小的技巧对于架构决策往往帮助很小。作者在 加入 ThoughtWorks 之后,参加了多个不同的 RichClient 项目的开发工作,使用 / 尝试过的语言包括 Java Swing、Flex/Adobe Air、.NET WinForm/.NET WPF,对于不同平台之间的种种有些体会。在本文中,作者将这些实践和原则进行了总结。

在讲述“一切皆异步”这条原则时,作者说到:

所有耗时的操作都应当异步进行。这是第一条、也是最重要的原则,违背了这条原则将会导致你的应用完全不可用。 考虑这样的一个功能:点击一个"更新股票信息"按钮,系统会从股票市场(第三方应用)获得最新的股票信息,并将信息更新到主界面。丝毫不考虑用户体验的写法:

void updateStockDataButton_clicked() {

stockData = stockDataService.getLatest(); // 从远程获取股票信息
updateUI(stockData); // 这个方法会更新界面
} 那么,当用户点击 updateStockDataButton 的时候,会有什么反应?难说。如果是一个无限带宽、无限计算资源的世界,这段代码直观又易 懂,而且工作的非常好:它会从第三方股票系统读到股票数据,并且更新到界面上。可惜不是。这段代码在现实世界工作的时候,当用户点击这个按钮,整个界面会 冻结──知道那种感觉吗?就是点完这个按钮,界面不动了;如果你在使用 Windows, 然后尝试拽住窗口到处移动,你会发现这个窗口经过的地方都是白的。你的客户不会理解你的程序实际上在很努力的从股票市场获得数据,他们只会很愤怒的说,这 个东西把我的机器弄死了!他们的思路被打断了。于是他们不再使用你的程序,你们的合作没了。你没钱了。你的狗也跑了。

在谈到“视图生命周期管理”时,作者将 Web 开发和 RichClient 开发进行了对比:

在 WEB 开发中,视图的生命周期很短:在进入页面的时候创建,在离开页面的时候销毁。一不小心页面被弄糟了,或者不能按照预期的渲染了,点下刷新按钮,整个世界一片清净。 WEB 下的视图导航也是如此自然。基于超链接的方式,每点击一次,就能够打开一个新的页面,旧的页面被浏览器销毁,新的页面诞生。(这里不考虑 AJAX 或者其他 JavaScript 特效)

如果把这种想法带入到 RichClient 开发,后果会很糟糕。每当点击按钮或者进行其他操作需要导航到新的窗口,你不加任何限制的创建新窗口或者新的视 图。然而 CPU 不是无限的。创建一个新的视图通常是很耗 CPU 和内存的。系统响应会变慢。用户会抱怨,拒绝付钱,于是因为饥饿,你的狗再次离开了你。

每次新创建视图产生的严重后果并不仅仅是非功能性的,还包括功能性的缺失。如果你用过 Skype,当你在给张三通话的时候,再次点击张三并且进行通话,你 会发现刚刚的通话界面会弹出来,而不是开启新窗口。在我们的一个项目中,有一个功能:点击软件界面上的电话号码就能开启一个新窗口,并直接连到桌上的电话 拨号通话。可以想象,如果每次都会弹出新的窗口,软件的逻辑是根本错误的。

查看文章全文 RichClient/RIA 原则与实践(上)

2009-03-16 08:421260

评论

发布
暂无评论
发现更多内容

语音质量监控

Damon

7月月更

Kubernetes资源编排系列之二: Helm篇

阿里云大数据AI技术

运维

采用Dubbo?还是Spring Cloud?

博文视点Broadview

零信任架构的实施规划——针对联邦系统管理员的规划指南

权说安全

mysql进阶(九)多表查询

No Silver Bullet

MySQL 多表查询 7月月更

异想天开 | 假如用中文写代码,是一种什么体验?

雨果

程序员 开发者

面试突击66:请求转发和请求重定向有什么区别?

王磊

Java面试题

ID生成器

ES_her0

7月月更

NFT市场格局仍未变化,Okaleido能否掀起新一轮波澜?

西柚子

OpenHarmony littlefs文件系统存储结构与IO性能优化分析

OpenHarmony开发者

OpenHarmony

即刻报名|前沿技术探索:如何让 Spark 更强劲、更灵活

Kyligence

spark 开源

ABAP-OOALV实现

桥下本有油菜花

SAP abap

C# 使用ListView控件实现文件查看大图标小图标,详细信息效果。

IC00

C# 7月月更

去哪儿旅行海量指标数据采集与存储

Qunar技术沙龙

如何判断透明LED显示屏质量优劣

Dylan

LED显示屏 led显示屏厂家

EMQ宣布赞助Erlang生态系统基金会(EEF),加速推动Erlang技术在全球的蓬勃发展

EMQ映云科技

erlang 物联网 IoT emqx 7月月更

ppdai站点登录参数加密解析,最短的文章,最棒的案例 com

梦想橡皮擦

Python 爬虫 7月月更

GPS原始坐标转百度地图坐标(纯C代码)

DS小龙哥

7月月更

Qt | Qt Creator功能

YOLO.

qt 7月月更

直播系统源码——短视频直播系统源码

开源直播系统源码

软件开发 直播系统 开源源码 短视频直播源码

重新认识生命世界,也重新认识我们自己

图灵教育

科普

CRMEB 多商户这些功能,你都用过吗?

CRMEB

静态成员函数访问非静态数据成员【C++】

攻城狮杰森

c++ 7月月更

工作流引擎在vivo营销自动化中的应用实践 | 引擎篇03

vivo互联网技术

工作流引擎 workflow Activiti 流程引擎

java零基础入门-File类(概念篇)

喵手

Java 7月月更

LeetCode-104. 二叉树的最大深度(java)

bug菌

Leet Code 7月月更

Qt|使用Http通讯下载文件

中国好公民st

HTTP qt 7月月更

中原银行代码智能重构实践

中原银行

生产力 插件 代码重构 中原银行 智能重构

【LeetCode】 数组嵌套Java题解

Albert

LeetCode 7月月更

CSS重复线性渐变之画格子

南城FE

CSS 前端 7月月更

3大类15小类前端代码规范,让团队代码统一规范起来!

南极一块修炼千年的大冰块

7月月更

文章:RichClient/RIA原则与实践(上)_Java_陈金洲_InfoQ精选文章