Android进阶之路——安卓编程规范

对于刚入行或者入行几年的程序员,或多或少,都有一点代码规范的问题,有些是没法子,各种需求变更,或入手各种别人写了一半的代码等等,因为时间问题,有时候你是心有余而力不足啊。虽然如此,我们还是得把代码规范养成一种习惯,这不仅仅是写出优美的代码,好的代码还能提高效率和提升性能的

一、包

  1. 包名全部采用小写,不用下划线区分单词

  2. 主包名采用[公司性质].[公司名称].[项目名称]的命名方式
    例如:翡翠教育做的手机助手包名edu.feicui.assistant

  3. 通用功能子包名采用[主包名].[通用名称]的命名方式
    常见通用功能如下表:

    包.png
    一般功能子包名采用[主包名].[模块名称].[子模块名称]的命名方式,例如:
    手机助手的闹钟模块包名 edu.feicui.assistant.alarm

  4. 只需导入用到的类,不得用*导入包下所有类

  5. 导入类时,系统类在上方,自定义类在下方

二、代码

  1. 代码主要采用大/小驼峰命名法,即除首字母外,每个单词首字母大写,整体首字母大小根据其它规范决定

  2. 类名、接口名、枚举名等首字母大写,若由多个单词组成,则其后每个单词首字母大写,例如:
    class ConfigManager{}

  3. 类名、接口名、枚举名等首字母大写,若由多个单词组成,则其后每个单词首字母大写,例如:
    class ConfigManager{}

  4. 继承自安卓组件的类,采用父类名作为后缀,例如:
    class LoginActivity extends Activity{}

  5. 自定义异常必须以Exception结尾

  6. 除for循环变量外,一律不得使用i、j、k等单字符作为变量名

  7. 定义数组时方括号紧随在原始类型之后,数组名称一般使用复数形式,例如:
    int[] arrays;

  8. 常量、枚举等均采用大写形式,用下划线区分各单词,例如:
    final static int DIALOG_ID_ALARM = 1;
    enum Season{SPRING, SUMMER, AUTUMN, WINTER};

  9. 全局变量添加所有者前缀:实例成员变量前缀m(表示member),类静态变量前缀s(表示static),例如:
    实例变量mRun
    类静态变量sInstance

  10. 控件变量添加组件前缀,顺序在所有者前缀之后,例如:
    全局名称mBtnNext
    局部名称btnNext

    常见控件前缀如下表:

    空间前缀.jpg

  11. 除单例模式外一般不得使用静态变量

  12. 常量一般使用final static修饰,根据需要使用可见性修饰符,例如:
    public static final int VISIBLE = 0x00000000;

  13. 一般方法名首字母小写,若由多个单词组成,则其后每个单词首字母大写

  14. 构造方法采用递增方式(参数多的写在后面)
    例如:
    public GameView(Context context) {
    this(context, null);
    }
    public GameView(Context context, AttributeSet attrs) {
    this(context, attrs, 0);
    }
    public GameView(Context context, AttributeSet attrs, int defStyle) {}

  15. 仅在项目内使用的实体类不使用JavaBean进行封装,直接将成员变量访问修饰符修改为非private,例如:
    class User{public String name,pwd;}

  16. 实体类中固定值的成员变量可设置成final,并通过构造函数初始化

  17. 实体类中不得随意修改的成员变量可添加下划线前缀以作区别,例如:
    class User{public int _id;}

  18. 一般不使用System.out输出,而是使用Log中的方法

  19. 使用BuildConfig.DEBUG标记对Log进行封装,只在调试时输出重要信息,正式版不输出

  20. 一般try……catch只捕获需要的异常

  21. catch块不得为空,至少应当将异常信息输出

三、资源

  1. 资源命名全部采用小写,各单词间以下划线区分

  2. 布局文件采用[前缀]_[功能模块].xml的命名方式,例如:
    MainActivity的布局activity_main.xml
    常见前缀如下表:

    常见前缀.png

  3. 图片采用[性质前缀][功能模块] [属性后缀].[扩展名]的方式,例如:
    主背景图片bg_main.png
    确定按钮按下btn_ok_presssed.png

    常见属性后缀如下表:

    常见属性后缀.png

  4. values目录下文件名称较固定,不得随意更改,常见名称如下:


    常见名称.png

四、注释

  1. 开源项目必须添加文件注释,非开源项目建议添加,例如:
    /*
    * @(#): Document.java
    * @project:IndentObjectNatation
    * @version: v1.1
    * @copyright: Copyright (C) 2013-2014 The Emerald Education
    * @description:
    * This file is a part of Indent Object Notation project.
    *
    * @modify:
    * ---- No.1 Modified By Mr. Tang At 2014-05-06 11:32 Based On 1.0 ----
    * Create this file.
    * ---- No.2 Modified By Mr. Zhang At 2014-05-06 11:32 Based On 1.0 ----
    * Make the class Document extend from the class Node.
    */

  2. 类定义一般需要写类注释,接口一般需要写接口注释,如果没有文件注释,则需要在类注释和接口注释中标出作者,例如:
    /**
    * Root of the ION tree, provides the access to the document's data.
    * <p>
    * Subclass of {@link Node}, Since elements, comments, etc. cannot exist
    * outside the context of a Document, the Document also contains the
    * factory methods needed to create these objects.
    * </p>
    *
    * @author Mr. Zhang
    */
    class Document {}

  3. 成员变量、静态变量、常量等添加属性注释,例如:
    /** This view is invisible. */
    public static final int INVISIBLE = 0x00000004;

  4. 关联性较大的多个成员变量等可以共用同一条注释,例如:
    /** The width and height of View. */
    private int mWidth, mHeight;

  5. public和protected方法必须添加方法注释,default和private方法建议添加方法注释,例如:
    /**
    * Writes {@code count} characters starting at {@code offset} in {@code buf}
    * to the target.
    *
    * @param buf
    * the non-null character array to write.
    * @param offset
    * the index of the first character in {@code buf} to write.
    * @param count
    * the maximum number of characters to write.
    * @return {@code true} if success, otherwise {@code false}
    * @throws IndexOutOfBoundsException
    * if {@code offset < 0} or {@code count < 0}, or if {@code
    * offset + count} is greater than the size of {@code buf}.
    * @throws IOException
    * if this writer is closed or another I/O error occurs.
    */
    public abstract boolean write(char[] buf, int offset, int count) throws IndexOutOfBoundsException, IOException;

  6. 若覆盖基类的方法,则可以不写方法注释,但必须用@Override标出,例如:
    @Override
    protected void onCreate(Bundle savedInstanceState) {}

  7. 不建议继续使用的方法用@Deprecated标出

  8. switch……case的每个条件一般添加简短说明,例如:
    switch (type) {
    case 1:// Android apps
    break;
    case 2:// Android games
    break;
    case 3:// iOS apps
    break;
    default:// Not a valid package
    break;
    }

  9. 如果if的条件大于2个,则必须写注释,例如:
    if (isBluetooth // If Bluetooth network is on
    || isWifi // If WLAN network is on
    || is3g // if 3g network is on
    ) {}

  10. 对于未完成的方法,使用TODO加以标记,例如:
    void write(byte[] buf, File file) {
    // TODO: Write buf to file
    }

  11. 若功能已完成,但存在效率等潜在问题时,使用XXX加以标记,例如:
    void parseXML(File file) {
    // XXX: Maybe SAX is better
    DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
    Document doc = builder.parse(file);
    }

  12. 若代码存在严重问题或仅用于调试,使用FIXME加以标记(注:存在FIXME标记的代码不能作为正式版发布)
    boolean login(String name, String pwd) {
    //FIXME: Remove this line before publishing
    System.out.println("name=" + name + ", password=" + pwd);
    if (users.containsKey(name) && users.get(name).equals(pwd))
    return true;
    return false;
    }

  13. 如果for、while等代码块过长,可以在结尾处标记循环变量,例如:
    for (int position = 0; position < 10; position++) {
    ……
    }// end for: position
    while(mRun){
    ……
    }// end while: mRun
    leo差不多就介绍这些了,欢迎补充!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,295评论 18 399
  • 一. Java基础部分.................................................
    wy_sure阅读 3,731评论 0 11
  • 新年要开运 撸一个女生最爱的元气妆容 2017年最流行就是介种BlingBling的底妆 女生要珍惜第一次化妆第一...
    朱家大菇凉印章眉粉阅读 191评论 0 0
  • 在这秋高气爽的下午,我们3.1班的读书社终于在梁老师的带领下成立啦……
    简单a快乐阅读 138评论 0 0