高效Java第四十四条为所有导出的API元素编写文档注释

要想一个API真正可用,就必须为其编写文档。
Javadoc根据源代码中特殊格式的文档注释自动生成API文档。

jdk5引入的Javadoc标签:{@literal}{@code}

为了正确地编写API文档,必须在每个被导出的类、接口、构造器、方法和域声明之前增加一个文档注释。
如果类是可序列化的,也应该对它的序列化形式编写文档。

方法的文档注释应该简洁地描述它和客户端之间的约定,这个约定应该说明这个方法做了什么,而不是说明它是如何完成这项工作的。

文档注释应该列举出这个方法的所有前置条件和后置条件

前置条件:为了使客户能够调用这个方法,而必须要满足的条件;
前置条件是由@throws标签针对未受检的异常所隐含描述的;每个未受检的异常都对应一个前提违例。
也可以在一些受影响的参数的@param标记中指定前置条件。

后置条件:在调用成功完成之后,那些条件必须要满足。

每个方法应该在文档中描述它的副作用

副作用:系统状态中可以观察到的变化,它不是为了获得后置条件而明确要求的变化。

文档注释应该描述类或者方法的线程安全性

方法文档注释

为了完整地描述方法的约定,方法的文档注释应该让每个参数都有一个@param标签,以及一个@return标签(除了这个方法的返回类型为void),以及对于该方法抛出的每个异常,无论是受检的还是未受检的,都有一个@throws标签。
跟在@param标签或者@return标签后面的文字应该是一个名词短语,描述了这个参数或者返回值所表示的值。
跟在@throws标签之后的文字应该包含单词if,紧接着是一个名词短语,它描述了这个异常将在什么样的条件下会被抛出。有时候,也会用算术表达式来代替名词短语。
按惯例,@param@return@throws标签后面的短语或者子句不用句点来结束。

{@code}标签

使该代码片段以代码字体进行呈现,并限制HTML标记和嵌套的Javadoc标签在代码片段中进行处理。允许在代码片段中使用小于号(<)。在JDK5之前,必须使用HTML标签和HTML转义,将代码片段包含在文档注释中(没有必要使用HTML的<code><tt>标签)。
{@code}避免了转义HTML元字符。

将多个代码示例包含在一个文档注释中可以使用<pre>{@code}{@code}</pre>

{@literal}除了不以代码字体渲染文本,跟@{code}标签一样。


文档注释在源代码和产生的文档中都应该是易于阅读的。如果无法同时满足两者,则产生的文档的可读性要优于源代码的可读性。

每个文档注释的第一句话是概要描述。概要描述必须独立地描述目标元素的功能。
为了避免混淆,同一个类或者接口中的两个成员或者构造器不应该使用相同的概要描述。

注意概要描述中是否包含句点,句点会过早地终止这个概要描述(如果有句点可以使用{@literal})。
概要描述很少是个完整的句子。
对于方法和构造函数,概要描述应该是个完整的动词短语(包含任何对象),它描述了该方法所执行的动作。

对于类、接口或域,概要描述应该是一个名词短语,它描述了该类或者接口的实例,或者域本身所代表的事物。

JDK5泛型、枚举 注解

当为泛型或者方法编写文档时,确保要在文档中说明所有的类型参数。

当为枚举类型编写文档时,要确保在文档中说明常量,以及类型,还有任何公开的方法。

为注解类型编写文档时,要确保在文档中说明所有成员,以及类型本身。
注释类型的概要描述要使用一个动词短语,说明当程序元素具有这种类型的注释时它表示什么意思。

包级私有的文档注释

包级私有的文档注释应该放在package-info.java文件中。package-info.java可以(非必须)包含包声明和包注解。

线程安全性

应该对类的线程安全级别进行说明。
如果类是可序列化的,应该对类的序列化形式进行说明。

继承方法注释

Javadoc具有“继承”方法注释的能力。如果API元素没有文档注释,Javadoc将会搜索最为适用的文档注释,接口的文档注释优于超类的文档注释。
{@inheritDoc}从超类中继承文档注释的部分内容。
类可以重用它所实现的接口的文档注释,而不需要拷贝这些注释。

HTML有效性检查器

降低文档注释出错的可能性。

复杂API

对于由多个相互关联的类组成的复杂API,有必要用一个外部文档来描述该API的总体结构,对文档注释进行补充,如果有这样的文档,相关的类或者包文档注释就应该包含一个对这个外部文档的链接。

总结

要为API编写文档,文档注释是最好、最有效的途径。
对于所有可导出的API元素来说,使用文档注释应该被看作是强制性的。
要采用一致的风格来遵循标准的约定。
在文档注释内部出现任何HTML标签都是允许的,但是HTML元字符必须要经过转义。

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

推荐阅读更多精彩内容

  • 如果要想使一个API真正可用,就必须为其编写文档。传统意义上的API文档是手动生成的,所以保持文档与代码同步是一件...
    真爱也枉然阅读 633评论 0 0
  • 阅读经典——《Effective Java》09 要想使一个API真正可用,就必须为其编写文档。Java提供了Ja...
    金戈大王阅读 3,683评论 8 11
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,642评论 18 139
  • 我说谢谢,感激地喝下了这杯咸咸的酥油茶。 随后坐下来唠家常,她把一些治理生活毛病的小技巧不厌其烦的教给我们。 她告...
    cheryl哟阅读 433评论 2 6
  • 纪事已远,恍若隔世的约定,风一般不着形迹。最放心不下的,还是你。为你点燃的浣花诗灯,一盏一盏次第而亮:为你酝酿的柔...
    紫儿姑娘阅读 237评论 0 0