博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[转载]EJB 倡导者: 什么是最佳实践?
阅读量:2447 次
发布时间:2019-05-10

本文共 2799 字,大约阅读时间需要 9 分钟。

EJB 倡导者: 什么是最佳实践?

在本文中,我们首先通过读者提出的问题解释了“最佳实践”的整体理念,接着介绍了有关应用程序体系结构的新知识,最后说明了 Enterprise JavaBeans™ 这一强大概念尚未得到大家广泛采用的原因。

摘自 。

在每个专栏中,EJB 倡导者都采用独特的前后衔接的对话方式与实际客户和开发人员进行交流,并在期间针对某一大家关注的设计问题推荐解决方案。其中并没有介绍任何确定性的细节,也没有提出“新颖的”或专有的体系结构。有关详细信息,请参见 。

亲爱的 EJB 倡导者:

不客气地说,我不相信“最佳”实践这一理念。您自己在 中说,“没有不好的模式,只有不好的模式应用。”难道最佳实践仅仅是说说而已?

署名:

For Better or For Worse

blue_rule.gif
c.gif
c.gif
u_bold.gif

亲爱的 For Better or For Worse:

感谢您就最佳理念提出的看法和问题。我表示非常理解。在这些讨论中,我发现很多人对“最佳”一词颇为不满,因为这个词显示出高人一等的优越感,就如同说我的实践比任何其他人的都要好一样。

事实上,这远非我之本意。最佳并非要拿“您”的实践与“我”的实践进行比较,而是针对一组需求对两种以上用于解决某个问题的方法所进行的比较。

例如,我们来看人们最早使用的策略之一:

"分而治之"

这一简单的语句运用了两种方法来解决一个问题:a) “分解”和 b) “解决”。但是您不会问到底是“分解”好还是“解决”好。真正的问题在于,何时停止分解而开始解决最佳。最佳实践的目的就是描述每种方法的最佳应用时机。因此,在这种情况下,对这一策略的“更好”(更完整地描述)措词可能是这样的:

"问题复杂时就分解,问题简单时就解决".

这句话意味着将两种方法运用于解决同一复杂问题,因为最终可以将复杂问题分解为足够简单的子问题。当然,您也可以先不进行分解而直接“解决”一个简单的问题。下图更清楚地说明了最佳实践的迭代(及常见的并行)特性。它将问题视为棱形,而将运用的解决方法视为矩形。连接问题和方法的弧线上的标签描述了在给定决策点上使用不同于其他方法的某一方法的原因:

图 1. 最佳实践的本质

进一步说,哪一种是最佳的呢,是无状态会话 Bean、有状态会话 Bean、实体 Bean,还是消息驱动 Bean?当然,答案要依赖于具体应用的需求。是需要立即响应,还是只需“即发即弃 (Fire and Forget)”请求?如果需要立即响应,那么是否需要“记住”请求发送的顺序或者要求请求间没有相互依赖性呢?针对这些需求,EJB 组件集能够客观地进行比较,从而找到针对实际应用情况的最佳方案。但是偶尔也会遇到某个复杂企业应用需要用到所有这些组件的情况。

还有一点需要强调的是:所谓的最佳是飘忽不定的。由于情况的不同,例如语言和平台在不断地发生变化,因此针对所要解决的问题而提出的最佳实践也会经常改变。详细地比较了 EJB 3 规范与目前的规范,您可以根据这些规范来考虑问题,从而找到一个折衷的方案。

针对实际企业需求探索如何最好地使用 EJB 组件是本 EJB 倡导者系列的真正目的。

希望这对您有所帮助。

好的,就先到此为止,

您的 EJB 倡导者

blue_rule.gif
c.gif
c.gif
u_bold.gif

亲爱的 EJB 倡导者:

非常感谢您花时间阐明最佳实践的意义。我也认为将其称为最佳听起来有些傲慢自大,而且我非常赞同将最佳实践看作针对具体问题简单地将一种方法与另一种方法进行比较这一理念。

但是,您最后关于情况变化的观点引出了一个有趣的话题:既然 EJB 规范也在不断改变,为何我们还要费尽周折学习关于 EJB 2 组件的最佳实践?此外,我还担心一个问题,EJB 3 是否将存在足够长的时间,谁能够给我保证?

谢谢。

For Better or For Worse

blue_rule.gif
c.gif
c.gif
u_bold.gif

亲爱的 For Better or For Worse:

诚然,事物不断地发生改变让人感到灰心,但是既然您和 EJB 倡导者一样都经历了过去的 COBOL 时代,那么您会意识到下面这句谚语背后的真义:“三十年河东,三十年河西。”还有一句对老手不会起什么安慰作用的格言是“江山易改,本性难移”(如果我以前用过这句格言,请您谅解)。

很抱歉使用这些民谚。我的观点是,当今的企业应用遇到的大多数问题与我们以往遇到的问题是相同的。计算机的运算速度永远不够快,内存或硬盘永远不够用,屏幕也永远不够大。因此,大多数用于构建解决方案的最佳实践都是相同的。

例如,今天用于设计“瘦客户端”应用的最佳实践与二十年前的最佳实践基本相同。主要的不同之处在于,屏幕不再是“绿颜色”的(并且并不仅有文本)。除了语言与平台的差异外,通用设计原则是相同的:将用于屏幕呈现的逻辑(“视图”)与获取和/设置数据的函数中的逻辑(“模型”)相分离。

下面是另一个示例。在 EJB 2 规范之前,总是认为在实体 Bean 周围使用会话 Bean Facade 是最佳的。有了 EJB 2 之后,“Home”实体可用于相同的目的——当存在一个代表用户角色的实体时,便不再需要。无论如何,常用的最佳实践是避免直接将持久层公开给客户,而应提供一个 Facade 来代替。创建 Facade 的细节可能会发生改变,但使用它一定是最佳实践,这适用于任何您能想象到的语言和平台――甚至是 COBOL CICS 应用!

这些示例说明,只要您能够首先关注通用设计原则,然后再考虑如何在某一平台上实现此原则的细节,就不会误入歧途。我忍不住想起了另一句古谚。获得最佳实践的方法就是应用策略:

"功能决定形式"

换言之,学习有关最佳实践的知识(即使是旧知识)总是值得的,因为每种方法的背后都隐含一条通用原则,这有助于您满足特定的需求。通常仅需要对需求的某一方面进行抽象(如用户不得不使用的平台和语言)。

Java Enterprise Edition (JEE) 规范之所以重要,是因为发明者们充分考虑到与企业应用相关的需求。不仅是功能部分,而且包括,如可靠性、可用性、效率、可维护性及可移植性。在每个组件和 API 背后都隐含一条通用设计原则,这使得该组件能够最好地应用于满足这些需求。在本系列中,我们已经研究了许多这样的原则,例如,EJB 组件如何将业务逻辑与提供本地或远程部署、安全、事务、持久化及异步调用相分离。此外,如果您还还记得,Java 是一种与平台无关、“编写一次,到处运行”的语言,有助于与其他语言编写的组件集成,那么对于构建实际的企业级应用,您还有什么要求呢?

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-130321/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-130321/

你可能感兴趣的文章
如何在Android上使用Amazon Underground免费获取大量应用内购买
查看>>
如何使用HDHomeRun在计算机,游戏机和其他设备上观看直播电视
查看>>
如何在没有智能手机的情况下使用Google Authenticator和其他两因素身份验证应用程序...
查看>>
如何显示密件抄送人员地址_什么是密件抄送,以及为什么不使用它会成为一个可怕的人...
查看>>
询问HTG:增强Wi-Fi连接性,校准显示器并执行基于计算机的恶作剧
查看>>
将code添加到上下文菜单_通过将选项卡添加到资源管理器,创建上下文菜单项等来轻松调整Windows 7和Vista...
查看>>
询问HTG:选择要备份的文件,将扫描仪用作复印机,并将iPad配置为第二台显示器...
查看>>
es dsl 提取不重复值_询问操作方法:诊断DSL挂断,从PowerPoint中提取媒体,将IE限制为单个网页...
查看>>
在Boxee中使用Pandora
查看>>
linux创建交换分区设置_如何在Linux上创建交换文件
查看>>
vim 关闭查找_如何打开或关闭查找我的iPad
查看>>
linux rev命令_如何在Linux上使用rev命令
查看>>
slack财报_如何将自己的表情符号添加到Slack
查看>>
juicer hic使用_使用Sound Juicer在Linux中翻录音频CD
查看>>
如何在Microsoft表单中添加分支
查看>>
在“提示”框中:删除Windows 8安全启动,从Media Center启动应用程序,并加快Windows安装速度...
查看>>
修改时序约束改变slack_如何更改Slack的默认表情符号肤色
查看>>
如何在iPhone,iPad和Mac上禁用Safari经常访问的起始页
查看>>
vscode变假期不提示_12个假期的家庭技术支持提示
查看>>
将电视频道徽标添加到Windows 7 Media Center
查看>>