[转载]EJB 倡导者: 什么是最佳实践?

2024-02-21 18:20

本文主要是介绍[转载]EJB 倡导者: 什么是最佳实践?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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


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

摘自 IBM WebSphere 开发者技术期刊

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

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

还有一点需要强调的是:所谓的最佳是飘忽不定的。由于情况的不同,例如语言和平台在不断地发生变化,因此针对所要解决的问题而提出的最佳实践也会经常改变。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”实体可用于相同的目的——当存在一个代表用户角色的实体时,便不再需要额外的会话 Bean 组件。无论如何,常用的最佳实践是避免直接将持久层公开给客户,而应提供一个 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/

这篇关于[转载]EJB 倡导者: 什么是最佳实践?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/732660

相关文章

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定