架构学习-包图
什么是包图
包图是在 UML 中用类似于文件夹的符号表示的模型元素的组合。
包图怎么用
系统中的每个元素都只能为一个包所有,一个包可嵌套在另一个包中。使用包图可以将相关元素归入一个系统。一个包中可包含附属包、图表或单个元素。
包图多用于类图,通常我们的系统中类都是分着包的,那么在使用之前肯定是要先引入这个包才可以使用。所以这里以类图的为例子来进行包图的一些规则叙述。
格式规则
样式:
关系:
泛化:
依赖:
use :使用关系,是一种默认的依赖关系,说明客户包(发出者)中的元素以某种方式使用提供者包(箭头指向的包)的公共元素,也就是说客户包依赖于提供者包。
import:引用关系,最普遍的包依赖类型,说明提供者包(箭头指向的包)的命名空间(包本身代表命名空间)将被添加到客户包(发出者)的命名空间中,客户包中的元素也能够访问提供者包的所有公共元素。
access:访问关系,只想使用提供者包中的元素,而不想将其命名空间合并则应使用该关系。
trace:追溯关系,想表示一个包到另一个包的历史发展,则需要使用《trace》关系来表示
包图中的元素可以有那些:
类
接口
构件
节点
协作
用例
其他包或图
包同样也和类一样拥有可见性(访问修饰符的概念):
- “+” :public
- “-” :private
- “#” :protected
原则:
每个包都必须有一个唯一的包名
包图中拥有的元素不得超出规范中的六种元素
最小化包间的依赖,最小化每个包中的 public , protected 元素个数,最大化每个包中 private 元素个数
包间关系不能出现循环依赖的情况
包中可以嵌套子包
**包图需体现出包间的层级关系,一个层级的包放到一张图。一般情况下,只绘制第一层级的包关系即可。