6、Java包的命名与划分

包的命名与划分

(一)使用Java包的目的

在了解做一件事之前,需要了解做这件事的目的。而使用Java包的目的大概如下:

1    对类进行归类,便于开发查找。

2    将软件在代码层面上模块化,提升可测试,可维护性。

3    将软件在代码层面上层次化,提升可读性,层次分明

(二)包的命名

要梳理包的依赖关系,首先我们要把握包的命名规则,一旦名字取的不好。在梳理包依赖关系时,便各种纠结。

Java的包是多个类的集合。包的命名,或以独立功能为准,或以层次划分为准。

(三)命名与依赖关系

项目中以独立功能命名的包,往往倾向被其它包依赖,而不能依赖其它包。

项目中以层次划分的包,往往倾向于向下依赖,而不能依赖于上层包。

总的来说,“包依赖关系体现出软件层次划分(竖向),功能模块划分(横向)”。

(四)获取代码中的包依赖关系

a.使用Java编译报错特性:同事通过Eclipse工具,对依赖包进行“refrector”操作(不勾选“update reference”选项),查看编译时的其它包报错,这样去确定哪些包依赖此包。从而逐个通过画图工具把包依赖关系绘制出来。(注:这种方式比较取巧,幸亏项目中的包并不是很多,同事花了30分钟就搞定了)

b.使用Eclipse插件modelgoon:http://www.oschina.net/p/modelgoon。利用此工具可以方便的导出包依赖关系。(注:同事觉得非常简单好用)

(五)对“单向依赖”的追求

从包依赖关系图中,通过箭头可以清晰的看到:一个包被哪些包依赖,而这个包又依赖哪些包。一般呢,一个包更倾向于“被单向依赖”,这意味这个包是可独立,可维护。对于软件测试来讲,单向依赖的包更容易进行单元测试。额外的,如果此包被广泛使用,则更多会将该包作为一个开发组件,并以一个独立项目的方式来对其进行维护。

(六)消灭“循环依赖”

“循环依赖”是指两个包之间互相依赖。消灭“循环依赖”有以下三种方法:

1  拆迁法。

A包的某些类或某些方法规划不合理,应该将其放在B包或者放在C包。

2  合并法。

B包所包含的业务属于A包的范围。将B包作为A包的子包。

3  依赖于接口法。

A包依赖B包,B包依赖A包的特定函数方法。这样可以通过依赖于抽象,来执行包与包之间的解耦。

(七)附转:包划分的几个小原则:

      1  一个包要么包含独立的功能,要么代表某层的功能。否则包的划分就没有意义,且查找起来很混乱。

      2 某类的子类。(比如接口或者虚类不同的实现)应当单独放到某个包中。

      3 假设A包依赖B包,那么B包不应该依赖A包。例如不应当在B包中出现包含A包中类的接口或属性。如果必须增加接口,则应当使用普通类或者B依赖的包中的类组织信息。

否则提取B包中的功能时,会牵扯出不需要的A包。

     4 如果A包,B包均依赖于C包,则包c不应当为A或B的子包。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏编程

设计模式启示录(二)

设计模式启示录(二) 在【设计模式启示录 (一)】中,重点介绍了设计模式的精髓(抽象),设计模式的分类(按抽象的目的进行分类)。在本篇中,将按照前述的七大分类,...

1677
来自专栏WindCoder

使用Project Lombok编写Fat-free java代码

没想到这次收到的是java的文章,更没想到的是内容是之前在北京实习时一家公司用到过的工具。当初看公司里的代码,发现里面没有直接创建getter/setter,后...

881
来自专栏java一日一条

我的编码习惯 - 参数校验和国际化规范

今天我们说说参数校验和国际化,这些代码没有什么技术含量,却大量充斥在业务代码上,很可能业务代码只有几行,参数校验代码却有十几行,非常影响代码阅读,所以很有必要把...

411
来自专栏phodal

前后端分离:使用 mest 做契约测试跟踪 API 接口变更

1043
来自专栏進无尽的文章

工具篇- FBMemoryProfiler 内存泄漏的自动化排查框架

应用开发到一定规模后,各种内存问题频频出现,还很难定位。你是否也体会过这种痛苦?随着我们工程的体量增长,代码结构变得越来越复杂。这时候很多内存问题就变得越来越难...

642
来自专栏北京马哥教育

原来 Python 还有这些实用的功能和特点!

在使用Python多年以后,我偶然发现了一些我们过去不知道的功能和特性。一些可以说是非常有用,但却没有充分利用。考虑到这一点,我编辑了一些你应该了解的Pytho...

792
来自专栏北京马哥教育

Python 工匠:善用变量来改善代码质量

1388
来自专栏腾讯Bugly的专栏

Android 内存优化总结&实践

导语 智能手机发展到今天已经有十几个年头,手机的软硬件都已经发生了翻天覆地的变化,特别是Android阵营,从一开始的一两百M到今天动辄4G,6G内存。然而大部...

3807
来自专栏JarvanMo的IT专栏

[译]Flutter响应式编程:Streams和BLoC

本文主要介绍Streams,Bloc和Reactive Programming(响应式编程)的概念。 理论和实践范例。

2149
来自专栏liulun

Nim教程【二】

第一篇教程1秒内就被管理员从首页踢掉了 管理员嫌内容太少,没有含金量,这次多写一些。 这应该是国内第一个关于Nim入门的系列教程 好,闲话休提,言归...

19710

扫码关注云+社区