注释
加上注释,格式尽量和规范保持一致
Java 程序有两类注释: 实现注释 (implementation comments) 和 文档注释 (document comments) 。
实现注释 是使用 /* … */ 和 // 界定的注释,用于注释代码或者注释特殊的实现。
文档注释 也称为 javadoc ,是 Java 所特有的,由 /** … */ 界定,可以通过 javadoc 工具转换成 HTML 文件,主要是描述代码段的说明,以编程手册的形式呈献给其他开发人员。
通常注释应该是给代码一个总的描述 , 或者提供从代码本身 不太容易看出的附加性信息 。注释的内容应只与读代码和理解代码有关。例如,关于相应的包 (package) 是如何构建,以及存放在什么目录中,不应该包括在注释中,对代码中 不太明显的设计意图进行说明 是应该的,但也应该 避免 对一些明显的信息进行 重复说明 ,尽量 避免 那些随着代码的维护 会过时的注释 。
注释的基本要求
方法及参数尽量加上注释,注释率不强制要求30%
1、适当注释 主要流程步骤 、 设计思路 和 关键细节 等,以辅助阅读和加深理解;
2、对 非 显而易见 的设计增加足够的注释,但要尽量 避免 注释信息和代码 过多的重复 ;
3、源程序的注释率 ( 注释行数占总行数的百分比 ) 应该在 30% 以上,不要求每个文件都达到这个要求,这个要求以模块为单位进行度量;
4、短注释可以跟在代码行的后面,但必须离代码够近。如果多个短注释出现在同一类型的代码后面,他们应该尽可能保持一种风格;
5、长注释应该加在其所描述的代码段之前,和前面的代码用空行分开,和所描述的代码段保持相同的缩进;
6、 注释要和代码保持一致,修改代码要同时修改相应的注释, 无用的注释要及时删除 ;
7、对于所有有物理含义的变量、常量,如果其命名不是充分自注释的,在声明时必须加以注释,说明其物理含义,变量、常量的注释应该在其上方相邻位置或右方;
8、不要在一行代码内部插入注释;
9、禁止使用注释方式保留废弃的代码,废弃的代码必须删除 ;
10、所有的枚举类型字段必须要有注释,说明每个数据项的用途;
文件头注释
不强制要求按照此规范处理
文件头注释位于文件最前端, package 语句之前,两者之间用空行隔开。
文件头注释采用 实现注释 格式,内容包括:公司版权声明、产品名称、模块名、文件创建时间、文件修订记录等。
示例:
/*
* ------------------------------------------------------------------
* Copyright © 2015 DtDream Scien ce and Technology Co.,Ltd. All rights reserved.
* ------------------------------------------------------------------
* Product: net
* Module Name: GateWay
* Date Created: 2015-02-09
* Description:
* ------------------------------------------------------------------
* Modification History
* DATE Name Description
* ------------------------------------------------------------------
* 2015-02-09 秦始皇 01234
* ------------------------------------------------------------------
*/
类和接口的注释
要求注释,但不强制要求完全按照此规范处理
类和接口注释使用 javadoc 风格, 置于 class 或者 interface 关键字所在行之前。
注释包括功能描述、作者、版本时间等内容。
@author作者
@since表示从哪个版本开始就有这个类或者接口
@see引用
@deprecated表示不建议使用该类或者接口
示例:
package com.dtdream.demo;
import java.util.HashMap;
import java.util.Map;
/**
* Description ...
* @author 秦始皇 01234
* @since 1.0
*/
public class DemoTest {
...
}
类方法的注释
要求注释,但不强制要求完全按照此规范处理。方法参数要仔细说明
类方法的注释使用 javadoc 风格, 置于 方法声明或定义之前。
注释内容:列出方法的一句话功能描述、作者、输入参数、输出参数、返回值、异常等。
@author作者
@param参数
@return返回值
@throws非运行时异常
@exception运行时异常
@since表示从哪个版本开始就有这个类或者接口
@deprecated表示不建议使用该类或者接口
示例:
【正确用法】
/**
* De s cription ...
* @author 秦始皇 01234
* @param long usrIndex 用户索引
* @return UsrInfo 用户信息对象
* @since 1.2 此方法添加于 1.2 版本
*/
public UsrInfo getUser(long usrIndex) {
...
}
类属性的注释
不强制要求按照此规范处理,但是必要的说明是需要的,格式尽量按照规范处理,
实体类用swagger模式也可
类属性的注释使用 javadoc 风格,放在属性 定义之前。
示例:
【格式 1 : 需要多行描述时采用格式 1 】
/**
* 属性描述
* 属性描述
*/
private String usrName;
【格式 2 : 单行描述采用格式 2 】
/** 属性描述 */
private String usrAddr;
方法内部代码块注释
方法里必要的注释还是需要的,格式尽量按照规范处理
方法内部的注释使用 实现注释 。
1、实现注释与其注释的代码在同一缩进级别或者位于代码行尾部;
示例:
【 错误用法】
private void setUsrInfo(String usrName, int usrAge) {
UsrInfo usrInfo = getUsrInfo(usrName);
/* 注释 */
doSomething();
/* 重设用户年龄 */
usrInfo.usrAge = usrAge;
/* 将用户置为在线状态 */
usrInfo.isOnLine = true;
/* 清零用户离线时间 */
usrInfo.offLineTime = 0;
}
【正确用法】
private void setUsrInfo(String usrName, int usrAge) {
UsrInfo usrInfo = getUsrInfo(usrName);
/* 注释 */
doSomething();
usrInfo.usrAge = usrAge; /* 重设用户年龄 */
usrInfo.isOnLine = true; /* 将用户置为在线状态 */
usrInfo.offLineTime = 0; /* 清零用户离线时间 */
}
2、注释不要封闭在由星号或者其他字符绘制的框架内;
示例:
【 错误用法】
private void setUsrInfo(String usrName, int usrAge) {
/*******************
* 注释 *
*******************/
doSomething();
}
【正确用法】
private void setUsrInfo(String usrName, int usrAge) {
/* 注释 */
doSomething();
}
3、注释应与其描述的代码相近,对代码的注释应放在其上方,并与其上面的代码用空行隔开;
示例:
【错误用法】
private void setUsrInfo(String usrName, int usrAge) {
/* 注释 1 */
doSomething1();
/* 注释 2 */
doSomething2();
}
【正确用法】
private void setUsrInfo(String usrName, int usrAge) {
/* 注释 1 */
doSomething1();
/* 注释 2 */
doSomething2();
}