《统一建模语言UML分层抽象建模机制 计算机专业外文翻译.docx》由会员分享,可在线阅读,更多相关《统一建模语言UML分层抽象建模机制 计算机专业外文翻译.docx(10页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、 统一建模语言 UML分层抽象建模机制摘要:在总结传统软件开发方法经验的基础上,严格遵守软件开发方法原则,从UML建模思想出发,对传统UML三层抽象建模结构进行了分析,并引入“抽象”和“分解”作为 UML 建模的核心思想;提出了UML分层抽象建模机制的构想,将计算机系统开发过程概括为对功能信元、结构信元、关联信元、实现信元和集成信元的提取过程,并以此作为 UML 建模的指导。有效了利用UML完整语义定义,克服了传统面向对象开发方法的缺陷;实现了建模过程从需求到分析的过渡以及功能和实现事实上的分离。关键词:统一建模语言;抽象;分解;分层建模;信元的一些概念1.1 使用情况一种使用情况是一个功能的
2、紧密单元,由一个系统或者类提供,前后一致的信息在外力的相互作用(叫做角色)下,一个或多个信息交换的顺序以及系统进行的活动。类一个类是有相似的结构,行为和关系的一套对象的描述符。一个类可以使用一套接口来指定操作的收集并提供环境。类可以是抽象和可执行的。接口一个接口是可以用于确定一种服务的操作收集的宣告,由一个类(对象)的实例提供。一个接口能命名一次行动的收集,并且指定他们的签名和协议。一个接口为它的行动没有提供实施(方法)。包一个包是一个类那样的组模型要素。一个包可以包含两个下属包和普通的模型要素。一些包可以是子系统或者模型。整个系统描述可以在它的其它任何事情上,认为是单个的高级子系统包。组成部
3、分组成部分是执行一个系统重要的,差不多独立和可替换的部分,来完成一个明确的清楚的系统功能。一个组成部分与接口相符并且提供一套物理接口来实现。一个组成部分可以是一个或更多类。2.两种模型化想法被提出全世界,对于软件有一个贪婪的需求。一方面,需要增加更多的一切功能性,灵活性,稳定性的软件,来保证软件复杂性,改进工具和人智力的限制;另一方面,当系统运转时,它变得越来越难以理解和表述大的行为模式,被一个系统的组成部分共同取得。建造完美对象系统的模型是整个系统设计的关键任务。由于这些原因,紧急发现是简化整个设计,对模型化的一些指导处理并且提高软件的效率发展。基于工程惯例的经验,我们提出两种模型化想法:抽
4、象概念和分解。他们也有两个基本关于人的想法,当人们能认识和管理他们试图解决的那些问题的复杂性。抽象概念是什么?面临一个问题时,当我们忽视分部和结时,我们经常想要知道它的普通属性。我们叫这种方法抽象概念。在软件工程领域,抽象概念有两种意思。第一是分析复杂系统时,设计者区分必要和非本质因素,为了得到摆脱非本质事情的本质问题。通过这样做,设计者正好能描述对象系统的结构并且改变无结构系统到系统的结构上。有意义的抽象概念的另一个不是在模块化过程期间,设计者一般对更高的标准化的低层的功能分层标准化。通过这样做,更高的层抽象概念的机制可以形成。抽象概念可以分解为两个层。更高的层被称为特定说明,指定抽象概念“
5、做什么”。低层被称为实现,是解决抽象概念的问题“怎样做”。因为抽象概念的应用,软件设计者能考虑在不同问题里的,在不同发展阶段期间的层抽象概念。基于这个策略分解分而治之。它是用来解决整体设计复杂性上的对象系统。在软件开发期间,分解作为模块化和体现信息隐藏。从概念技术,分解抽象概念的提炼的接近,例如,一步一步的精炼的想法。分解的反面,分解组成之后是一种软件实现的重要方法。3.在UML里的抽象概念的3 个分层结构图1显示了在UML里抽象概念的传统的3 个分层结构。我们使用抽象概念和分解的方法来分析它。3.1 概念在这个层期间,对象系统的全部模型要素是在应用领域中概念。使他们认识到,这些概念由软件与程
6、序独立的提供。3.2 说明在这个层期间,全部概念逐渐形成单元,它们相互作用,彼此取得明确的功能,高层的分解和低层的抽象概念,因为它只描述隐藏实现他们时由功能单元提供的接口。3.3 实施这个层描述实现功能单位。这个层的模型或更多为大多数人所熟知。但是实际上,模式的那些层说明更赞成在那些开发者之间彼此的理解和交流。的抽象观念模型化机制基于抽象概念的3 个分层结构,我们提出UML抽象概念模型化机制,用图2 表示。在这个模型化机制过程中,我们集中于关键消息支配模型化处理和抽象他们的5不同单元:功能单元,结构单元,服务单元,实施单元和积分单元,描述5个在不同阶段的抽象概念层。在以前的阶段产生的单元是在更
7、晚的阶段产生的单元的抽象概念。4.1 功能单元人们对应用领域的熟识是从它的功能开始的。理解功能在应用领域中,帮助理解。因此功能单元的作用是用这把从应用领域和模型化设计决定的钥匙来开车,对于它来说是整个模型化过程。功能单元属于概念层抽象概念结构,在UML里和作为使用情况体现。使用案例可以是更大或是一个用户的综合描述提供的小目标。模型化使用案例是人栩栩如生重现在应用领域的精神印象。使用案例拥有强大的远的影响设计决定。对找到完美的使用案例,设计者依赖经验,迭代,和探索法。因此当上升使用来自系统的案例时,我们应该再三考虑:根据那些角色的需求,那个功能应该被系统提供,通过那些角色,多少信息应该被读,创造
8、,删除,修改,或者储存,通过系统,需要输入和输出中的多少类型,以及输入来自哪输出又去向哪。把函数定义为单元是一个先进的需求分析,设计延续其他类单元的高级设计并且意识到他们过后增加彼此的相互作用。4.2 结构单元在为他们确定函数单元和模型化之后,我们可以考虑选择过去常常彼此相互作用完成功能单元描述的一个具体的功能结构为单元。结构单元是形成整个软件的单位。对他们进行好的选取是系统的基础。结构单元也属于概念层并且作为类体现以及对象。类和对象是在面向对象的设计过程中的基本要素。在应用过程中的实体类和在UML里的他们的协会的领域地图。在这服务水平的类作为一个词汇必要的设计概念和为在那之后做更详细的基于类
9、的设计作为一个基础。很多事情和类模型抽象概念一样有用,并非在面向对象里的类阶层实施。在这水平上,他们一定要从那些最后实施那里远距离的,可以帮助应用领域理解。这里给出一些类选择的一些指导:只用文献证明应用领域的静止的实体,节约使用继承或通过忽视方法的行为。4.3 服务单元到目前为止我们确定的单元鉴定的信息是在应用过程中的全部固定角色领土。例如,我们命名升降机和电动机为这个升降机控制系统内的类,但是忽视类似像层那样升降机的那些问题和电动机运转的方式。当他们工作时,单元服务得到的目的是发现那些服务在他们之间以单元结构提供。总而言之,建立基础,建造在结构单元之间的动态的合作。正如在上面所描述的那样,说
10、明层是理解UML 模型的最好入口。知道它提供的服务,是认识到体系单元的唯一的路径。在UML里,服务单元作为体系单元的接口封装。因为在面向对象系统里,每个实体和它需要或提供的服务被制订进一种类和它的接口。每个类提供并且使用通过它的接口的服务,具体的说,活动在接口里确定。我们进一步精炼而分开自己的那些接口类,改变类从概念水平到说明水平。因此工作的关键是分解并且精炼结构单元,指定他们提供并且在隐藏实现细节时需要的服务。实施单元到目前为止我们已经指定整个系统的框架,来实施抽象概念层。现在该集中我们的注意力,确定实施单元。换句话说,在服务单元过程中实现每次操作的方法。在UML内,方法的实现设计相应算法并
11、且使用具体程序语言来实施它。作为结果,零部件软件和软件设计的主要工作被完成。我们也能拿现有的组成部分实现服务单元。UML不仅基于OO而且此外还支持软件重用。与组成部分的积累一起,利用存在合理的资源能从头到脚避免过程。4.5 综合单元综合单元集中于实现整个系统。我们知道现在系统是经常分开软件和部分硬件,在通信网络上方分配。系统集成已经变得越来越重要。系统集成的任务是制订每种模型化要素类、物体、操作、方法等等,在功能被确定单元,单元结构,单元和单元实施服务对物理计算机节点。根据系统,网络拓扑结构结合不同计算机和不同的系统操作。因此在他们上运行,要在这个层做的主要工作是研究对象系统硬件的拓扑结构和软
12、件。我们把信息与系统集成有关的这些作为综合单元。在UML里的综合单元作为节点体现和他们的连接,组成部分和接口、对象。5.结论我们建造分层的抽象概念模型化机制的动力是提供在UML 模型化过程中的研究线索。更多工作应该被精炼,选择5种工作多种单元和UML 制订的定义,以及结合面向对象的技术并且软件重用技术完全最大化的提高我们的产品质量。1 Buhr R J A, Casselman R S. Use case maps for object-oriented systems. New York: Prentice-Hall International Inc,19992 Zhang Fengli,
13、 GeXiaofeng, Lu Xianliang. Design and implement of comprehensive query system based on data ware house. Journal of University of Electronic Science and Technology of China, 1999 3 Kruchten Philippe. Modeling component systems with the unified modeling language. Rational Software Corp,19984 Mei DenHu
14、a.A object-oriented multicomputer software system reliabilitymodel. Journal of University of Electronic Science and Technology of China, 19996 Wu Yue, Yu Shui, Fu Yan, et al. On Internet database accessing technology. Journal of University of Electronic Science and Technology of China, 2001原文2:UML M
15、odeling Mechanism Based on Layered Structure of Abstraction College of Computer Science and Engineering, UEST of China Chengdu 610054 Wu YueLuoWumanAbstract : This paper introduces UML(Unified Modeling Language) modeling method. Based on the experience of traditional software development method and
16、the analysis of traditional three layered structureofabstraction in UML, two ideas of abstraction and decomposition are brought forward as the kernel modeling ideas of UML to construct the abstraction modeling mechanism of UML that the process of computer system into the process of picking up five c
17、ells: the function cell , the structure cell, the service cell, the implementation cell and the integration cell .The purpose is to make use of the whole semantics of UML effectively and to get over imitation of traditional OO method and eventually to achieve the perfectly transition from requiremen
18、t to analysisand virtual separation of function and implementation. Key words : unified modeling language; abstraction; decomposition; layered modeling; cell 1 . Some Concepts of UML 1.1 Use case An use case is a coherent unit of functionality provided by a system or class as manifested by sequences
19、 of messages exchanged among the system and one or more outside interactors (called actors) together with actions performed by the system. . 1.2 Class A class is the descriptor for a set of objects with similar structure, behavior, and relationships. A class may use a set of interfaces to specify co
20、llections of operations it provides to its environment. Class may be abstract and executable. 1.3 Interface An interface is a declaration of a collection of operations that may be used for defining a service offered by an instance of class (object). An interface serves to name a collection of operat
21、ions and specify their signatures and protocols. An interface offers no implementation (method) for any of its operations. 1.4 Package A package is a group of model elements such as classes. A package may contain both subordinate packages and ordinary model elements. Some packages may be subsystems
22、or models. The entire system description can be thought of as a single high-level subsystem package with anything else in it. 1.5 Component A component is a non-trivial, nearly independent and replaceable part of a system that fulfills a clear function in the context of a well-defined architecture.
23、A component conforms to and provides the physical realization of a set of interfaces. A component may be one or more class. 2 . Two Modeling Ideas Brought Forward Worldwide , there is an insatiable demand for software. On one hand, ever increasing demands on software for more of everythingfunctional
24、ity, flexibility, reusability, robustness s eem to ensure the software complexity keep pushing the limits of both tools and human intellect; on the other hand, it becomes more and more difficult to understand and express the large-grained behavior patterns that will be jointly achieved by the compon
25、ents of a system while the system is running. So constructing perfect models for object system is the key task of the whole system design. For these reasons, it is urgent to find some guidance for modeling to simplify the whole design process and enhance the efficiency of software development. Based
26、 on the experiences of engineering practices, we bring forward two kernel modeling ideas: abstraction and decomposition. They are also two basic thoughts of human when human recognize the world and manage the complexity of the problems that they are trying to resolve. What is abstraction? When faced
27、 with a problem, we often want to know its common attributes while ignore the branches and knots. We call this method abstraction. In the field of software engineering, abstraction has two meanings. The first is that when analyzing the complex systems, designers distinguish he essential and nonessen
28、tial factors and get rid of the nonessential things in order to get the essence of the problem. By doing so, designers can describe the structure of the object systems exactly and transform the structure less systems to the structural systems. Another meaning of abstraction is that during the proces
29、s of modularization, designers generalize the functions of the lower layer modular to the higher layer modular. By doing so, mechanism of higher layer abstraction can be formed. Abstraction can be decomposed into two layers. The higher layer is called specification, which specifies the abstraction w
30、hat to do. The lower layer is called realization, which resolves the problem of abstraction “how to do”. Because of the application of abstraction, software designers are able to consider problems in different layers of abstraction during different phases of development. Decomposition is based on th
31、e strategy of divide and rule. It is used to resolve the design complexity of the object system as a whole. Decomposition is embodied as “modularization and information concealment” during the software development. From the view of technology, decomposition is the approach of the concretion of abstr
32、action, for example, the idea of refinement step by step. Reverse to decomposition, composition is an important approach of software implementation after decomposition. 3 . Three Layered Structure of Abstraction in UML Fig .l shows the traditional three layered structure of abstraction in UML. We us
33、e the ideas of abstraction and decomposition to analyze it. 3.1 Conception During this layer, all the model elements picked up from object system are conceptions in application domain. These conceptions are provided independent of the software and programming languages that realize them. 3.2 Specifi
34、cation During this layer, all the concepts are evolved into the units that interact with each other to achieve an explicit function, which is the decomposition of the upper layer and the abstraction of the lower layer because it only describes the interfaces provided by function units while conceali
35、ng the realization of them. 3.3 Implementation This layer describes the realization of the function units. The models of this layer perhaps are more familiar to most of people. But in fact, the models of the specification layer are more in favor of the understanding and communication with each other
36、 between the developers. 4 . Abstraction Modeling Mechanism of UML Based on the three layered structure of abstraction, we bring forward the abstraction modeling mechanism of UML, shown in Fig.2. In this modeling mechanism, we focus on the key messages dominating the modeling process and abstract th
37、em to five different cells: the function cell, the structure cell, the service cell, the implementation cell and the integration cell, which represent five kernel stages at different abstraction layers. The cells born in former stages are the abstraction of the cells born in later stages. 4.1 Functi
38、on Cell Peoplesacquaintanceof the application domain begins with its functions in i t. Comprehending the functions aids in application domain understanding . So picking up the function cells will drive the key design decisions from the application domain and modeling, for it is the exordium of the w
39、hole modeling process. The function cell belongs to the conception layer of the abstraction structure in UML and is embodied as use cases. An use case may be larger or smaller as long as it provides the integrated description of one user target. Modeling use cases is the lifelike recurrence of peopl
40、es mental impression in application domain. Use cases have a strong effect on further design decisions. To find perfect use cases, designers rely on experience, iteration, and heuristics. So when picking up use cases from the system, we should think over: which functions should be provided by the sy
41、stem according to the demands of the actors, how many kinds of information should be read, created, deleted, modified, or stored by the actors, how many types of inputs and outputs are needed by systems, and where do the inputs come and outputs go. Defining function cells is an advanced requirement
42、analysis that segues seamlessly into high-level design for other kinds of cells are designed and added later to interact with each other to realize them. 4.2 Structure Cell After defining the function cells and modeling for them, we may consider selecting structure cells used to interact with each o
43、ther to accomplish a specific function described by the function cell. Structure cells are the units forming the whole software. A well selection of them is the foundation of the extensibility of the system. Structure cell also belongs to the conception layer and is embodied as classes and objects.
44、Classes and objects are the basic elements in object oriented design. The entities in the application domain map into classes and their associations in UML. Classes at this level serve as a vocabulary of essential design concepts and act as a basis for doing more detailed class-based design afterwar
45、ds. Classes are useful as abstract concepts to model many things, not just class hierarchies in object oriented implementation. So at this level, they must be quite distant from the final implementation, thus aid in application domain understanding. Here give some guidelines for the selection of the
46、 classes at this level: only documenting the static entities of the application domain, using inheritance sparingly or downplaying behavior by ignoring methods. 4.3 Service Cell Up to now the information identified by the cells we defined are all static characters in application domain. For example,
47、 we name the elevator and motor as the classes in the elevator controlling system, but ignore the problems such as which floor the elevator will go and the way the motor works. The purpose of picking up the service cells is to find the services provided by structure cells and the associations betwee
48、n them when they work. In one word, establish the foundation for constructing the dynamic associations between structure cells. As described above, the specification layer is the best entrance for understanding the UML models. The only way to realize the structure cell is to know the services it provides. In UML, service cells are encapsulated as the interfaces in structure cells. Because in object-