日期:2013-12-07  浏览次数:20694 次

PowerDesigner UML 建模简介
David Dichmann,PowerDesigner 产品经理,Sybase, Inc.

由于引入了 UML,PowerDesigner 8.0 支持使用例图、序列图和类图的面向对象分析与设计(OOAD)。在即将发布的 9.0 版中,PowerDesigner 加强了对 UML 的支持,提供了活动图表和组件图表、改进了分析方法并加强了与开发过程的集成。

PowerDesigner 能够协助您构建顺应现代 IT 发展的传统商务和电子商务系统,使用 Java 等面向对象的言语以及 XML 等新技术,以物理或虚拟的方式与我们的数据库技术合并。我们的目标是依据您的需求,提供随时随地访问信息、控制业务流程的能力,并通过计算机和最新技术赋予企业在当今任何市场上先拔头筹的竞争优势。

我们的分析方法和设计技术将会是多种多样的,从业务流程建模,到 UML 面向对象分析和设计,以及传统的关系建模等。本文将协助您深入了解 UML 这项强大的技术,它可以协助您的企业创建出高效的传统商务和电子商务系统。
面向对象的分析
在您预备为企业作出系统和软件投资前,必须首先了解企业的实际需求,明确所部署的技术将如何协助您的企业获取更大的成功。

您可以使用 UML,借助用例图、序列图和活动图来进行分析。这些图表将协助您规划系统的范围、动态功用、以及表现方式等。不必考虑实施细节,您希望获得的只是按照您的需求而表现的系统功用。
用例图(The Use Case Diagram)
UML 用例图提供了一个系统环境的建模方式。它能够协助您确定系统/使用程序的外部和内部元素以及系统范围。作为图形建模模式,它在您需求与所收集的系统需求进行对话时也将有所协助,对于研制成品的开发团队来说,更是有着举足轻重的重要性。对于企业的所有者,或第一次接触该软件产品的用户也有很大的协助作用。用例图能够以可视化的方式,表达系统如何满足所收集的业务规则,以及特定的用户需求等信息。

在项目后期,也能够用到 UML 用例图。您可以通过用例图中定义的需求来协助测试项目的相关功用。您不只可以验证系统功用能否无错误(无崩溃或明显的非逻辑呼应),还可以验证系统运转时能否按照要求,执行了指定命令。这样,您可以测试系统能否完全满足了要求,以确信成品可以投入生产——也就是说,它已完全满足了用户的需求。

只要确保满足了合理、实用的各项需求,才能确保 IT 项目的更大成功。




图 1 – 公司客户下订单的用例图
序列图(The Sequence Diagram)
您可以使用 UML 序列图细化需求并对设计元素进行链接。序列图允许高层和低层对象间的交互文档。该交互在角色(与用例图中的角色相反)和类实例(运转于计算机内存中的技术对象和细节对象)之间显示。

通过序列图,您可以按照系统特定方案中事件(音讯)的精确顺序来描述随时间变化的系统行为。使用序列图进行用例分析并引导设计:您可以决定将对用例图所定义的管理任务担任的系统对象类型,并决定哪种对象将管理系统内外的“会话”或通信。由于音讯已从序列图中抽出,您可以描述类和接口(我们最后要编译和部署的代码元素)所需的某些关键操作(方法)。

 

图 2 – 贷款使用程序的序列图
活动图(The Activity Diagram)
UML 活动图设计用于协助您了解系统中对象的动态变化。用于描述某一特定类或一组类如何协同任务。与序列图有所不同,活动图不是一系列与时间相关的通信,而是从一个任务到另一任务的控制转移,同时指定谁(哪个对象)对发生的任务担任。 

UML 活动图也是业务流程的技术视图。可对业务任务流进行分析或在“业务流程建模”任务后可获得活动图。 

活动图还可协助结构系统内元素的详细动态视图(EJB 如何互操作等)。


图 3 – 活动图 – 处理订单
通过分析推动设计
通过分析模型可捕获独立于实施细节之外的系统意向和预期行为,与使用的言语、部署的使用程序服务器或使用的体系结构都没有关系。但是,设计阶段开始后,一切都发生了变化。您必须进入生产环境的细节并将软件构建至特定的体系结构。设计是对系统的实施。

如果设计是由分析得到的,您可以愈加确信所编写的系统行为的正确性,确认所开发的成果将是一个按需求构建的系统。您将获得高度成功——让用户得到所需求的系统。您还可以直接利用分析得出的信息而无需在设计过程中重重生成,从而缩减开发时间,由于不必“重新复制”任何任务,因此减少了人为错误。

通过分析,我们可获得什么呢?通过用例图可以发现对象并促进类和接口的创建。一个或更多类和接口可以实现一个角色,您可以在角色定义中直接创建类和接口。您还可以将角色链接到现有的类和接口,显示如何使用一条代码来满足所分析的多个元素。

通过序列图可以发现方法并促进类操作的创建。如果您需求向类发送音讯,您可以调用该类的方法。序列图中的音讯可以用来自动创建操作或链接到现有操作。您可以通过链接跟踪方法的功用,包括将哪些作为输入内容和必须前往哪些内容等等。
设计所包含的内容
您曾经知道要构建的内容,如今您需求表述如何构建。您需求确定业务逻辑所在的位置:可以置于使用程序服务器的 EJB 等组件中,也可以置于使用 VB 或 PowerBuilder 等言语、作为客户端使用程序一部分的类或组件中,或者做为触发器和过程内置于关系数据库中。您需求依据需求做出一些选择,包括扩展性、安全、功用和可访问性等方面。

UML 类图和组件图将用于定义详细的技术系统静态结构。 
类图 (The Class Diagram)
UML 类图、业务逻辑和所有支持结构一同被用于定义全部的代码结构。既然类图用来模仿开发中所维护的实际代码,显然它是 Java 或 PowerBuilder 等对象言语的概括性表述。您还可以使用 UML 类图来概括 XML 中的复杂结构,令其更易于开发和理解。

可以从 UML 类图上生成代码。还可以在开发过程中编辑该代码以完善、测试和部署最终运转的使用程序。由于 PowerDesigner 在对象言语和 UML 类图之间具有 1:1 的映射功用,您还可以实施反向工程代码,读取源文件并创建新的类图。您可以更深入地理解现有系统并简化集成和维护任务。

 



图 4 – 订单输入系统的类图
组件图(The Component Diagram)
UML 组件图将被用于在更大的黑匣视图(Black Box View)中描述高级对象的定义和相关性。它仍然是一个设计模型,并且是代码的直接概括。例如,一个 EJB 的组件标识直接链接到实施所必需的一系列类和接口,并将生成所需代码来推动最终 bean 的开发。




图 5 – 订单输入系统的组件图

组件图比组件体系结构的代码层视图更容易理解和管理。还可以通过编写组件接口的文档来实现代码的共享和反复使用,用户无需(或很少)了解组件的实施细节即可在其他项目和系统中使用这些代码。




图 6 – 客户实体 bean 的 EJB 模型:
循环叠代工程
世界不是原封不动的,您的 IT 项目也如此。在您了解需求,通过分析进行了设计,并构建了系统的某些元素后,必然还会遇到新的变化,如要更新定义,又或者现有用例图中存在某些需求改正的错误,代码在 IDE 和文本编辑器中被编辑以及数据库被DBA 优化等。必须管理和掌握所有需求更改的细节,以确保所构建的系统能够与业务需求保持分歧。

往返工程的一个方案是当代码在开发过程中被更改时,需求在类图中反映出来。具体细节如下:
创建类图并将业务逻辑元素添加到模型中生成文件系统的使用程序代码在 IDE 或文本编辑器中编辑代码编辑设计,此时忽略在生成的代码中所发生的更改对编辑内容实施反向工程,直到与现有类图分歧将设计过程中完成的任务与开发时编辑的内容同步(合并)生成新代码,该代码是设计代码和开发人员更改代码的总和
当对类图进行了修正以反映新的设计内容时,应该使用同步/合并技术防止丢失开发人员的任务成果,同时允许设计人员接受或拒绝开发过程中所做的更改。这样,PowerDesigner 令 IT 能够完全控制体系结构,这正是制胜的关键。

PowerDesigner 的功用并不是仅限于此!如今设计模型已被更新,您可以将这些更改链接到分析中。有可能您在分析中发现了新的需求,可以将这一更改反映到设计中并编写代码。使用 PowerDesigner 中领先的 Compare/Me