Android开发规范:包命名规范

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ddnosh/article/details/84175264
  • 简介
    android包目录的命名的好坏,会直接影响到整个app工程后期的开发效率和扩展性。
    所以在创建项目的初期,建立一个好的包目录的命名非常重要。
    一般来说android包命名的方式有两种:PBL和PBF。
    我们现在分别来介绍下这两种命名规则以及各自的优缺点。

  • PBL(Package By Layer)
    字面意思是按层次划分,实际上就是按照职能划分,比如app里面分为activity、fragment、view、service、db、net、util、base等。
    顾名思义,activity的职能是管理所有的activity类,只要这个类是extends Activity的,都放到这个目录下面;以此类推,fragment目录放所有extends Fragment的类。view放置自定义的View,net放置管理网络相关的,bean放置
    bean对象。
    参考如下目录结构:

└─src
    └─com
        └─android
            └─demo
                ├─activity
                │      LoginActivity.java
                │      SettingActivity.java
                │      
                ├─bean
                │      UserBean.java
                │      
                ├─db
                │      DBManager.java
                │      
                ├─fragment
                │      NewsFragment.java
                │      PictureFragment.java
                │      
                ├─net
                │      RetrofitManager.java
                │      
                └─service
                        BackgroundService.java

这也是我们以前开发项目常用的包目录结构。
PBL的优点:

  1. 项目结构简洁明了,上手快;
  2. 适合开发人员不多,后期变动不大的项目;

PBL的缺点:

  1. 低内聚
    同一个包下会是各种功能模块的集合。比如activity包,下面放置了登录、设置等功能模块;这几个模块本身并没有很强的关联性,却放在了一起,聚合性降低。

  2. 高耦合
    这里讲的高耦合是指package之间的关联性,比如activity包内的类往往引用到了fragment或者view里面的类,package之间的关联性比较紧密。

  3. 开发效率
    开发一个功能模块,往往需要到不同的package里面来回切换。比如登录模块,需要到activity里面开发LoginActivity,Activity往往包含了fragment,这时又需要去fragment里面找到对应的fragment来开发。package之间相互切换确实会影响开发效率。同样,修改、调试一个功能也需要这样的操作。如果后期项目功能和代码增多,会大大降低开发效率。

  4. PBL(Package By Feature)
    PBL的意思是:按照功能划分包名。就是app里面有什么功能模块,就以这个功能模块作为包名,所有这个功能模块的开发都在这个包名下进行。
    我们看一个很经典的google iosched app的包结构,相信大家对比PBL很容易看出差别。
    在这里插入图片描述

PBF的优点:

  1. 高内聚
    所有功能都在一个包名下面完成。比如map模块:
    在这里插入图片描述
    所有的activity和fragment都在这里面,包括相关的util。
    这里需要说明的是,功能模块里面的util一般都是和这个功能模块强相关的,如果是功能模块包名外的util包名,一般放置的是跟项目相关的util类,能作用于整个或者多个功能模块的util类。
    其它包名类推,比如ui包名下面放置了BaseActivity。
  2. 低耦合
    package之间没有很强的关联性,开发此模块的功能只需要在对应的包名下面进行开发即可,除了基础类外,一般不需要引入其它包的类。
  3. 开发效率高
    增删改查都只要在对应的包名下面进行即可,后面的开发人员接手也方便。
  4. 便于后期组件化转化
    如果项目是按照PBF来进行包名划分的,后期进行组件化改造的时候就会非常方便。
    可以直接把功能模块独立出来作为一个组件,同时划分好代码边界,对外保留好访问接口。
    比如上面的map功能,我们可以把map独立出来作为一个library工程。

猜你喜欢

转载自blog.csdn.net/ddnosh/article/details/84175264