组件粒度划分与组件的集成
转自:http://blog.csdn.net/tyrone1979/archive/2005/12/17/554646.aspx
1.介绍
由于组件的概念没有模式化,以及现有技术种类的多样化,组件的形式也是多样的。大多数项目在开发过程中所考虑的组件划分方式和方法都不相同,这样导致现有项目中的组件很难重用到其它项目中。因此重组现有组件,把现有组件源代码重新分割或组合为新的组件的需求也越来越多。本文在源代码级别上根据源代码之间的调用关系,自定义了组件的划分粒度和组件的集成方法。但在此声明本文的组件集成方法不具有唯一性和最优性。
2.概念
组件:提供可重用的功能的类库或函数库;
组件粒度:组件的源代码文件越少,粒度越大。用户可以根据不同的需求定义组件粒度的大小;
调用关系:文件之间有函数/方法/属性/变量调用或继承关系则称文件之间有关系;
Layer:一个layer表示一个组件,Layer后面的数字表示组件的粒度,数字越大粒度越小,既组件的源代码文件越多,复杂度越大;
组件集成:根据现有源代码之间的调用关系,和本文定义法则和可定制约束条件来自动组合组件。
法则:没有调用关系的源代码不能组合为一个组件;
可选择以下2个约束条件中的一个:
1 组件内源文件不能调用组件外的源文件;
2 组件不能和多个文件组合为二个以上不同组件;
3.方法
下面是根据源文件的调用关系重组不同粒度的组件
表示一个源文件, .java, .cpp, .c, .s等
表示左边的源文件内的某函数/方法调用右边源文件
表示叶子节点,既不调用其它文件(不包括OS类库/函数库)