Javadoc Explained

Javadoc is a documentation generator created by Sun Microsystems for the Java language (now owned by Oracle Corporation) for generating API documentation in HTML format from Java source code. The HTML format is used for adding the convenience of being able to hyperlink related documents together.[1]

The "doc comments" format[2] used by Javadoc is the de facto industry standard for documenting Java classes. Some IDEs,[3] like IntelliJ IDEA, NetBeans and Eclipse, automatically generate Javadoc templates. Many file editors assist the user in producing Javadoc source and use the Javadoc info as internal references for the programmer.

Javadoc also provides an API for creating doclets and taglets, which allows users to analyze the structure of a Java application. This is how JDiff can generate reports of what changed between two versions of an API.

Javadoc does not affect performance in Java as all comments are removed at compilation time. Writing comments and Javadoc is for better understanding the code and thus better maintaining it.

History

Javadoc was an early Java language documentation generator.[4] Prior to the use of documentation generators it was customary to use technical writers who would typically write only standalone documentation for the software,[5] but it was much harder to keep this documentation in sync with the software itself.

Javadoc has been used by Java since the first release, and is usually updated upon every new release of the Java Development Kit.

The @field syntax of Javadoc has been emulated by documentation systems for other languages, including the cross-language Doxygen, the JSDoc system for JavaScript, EDoc for Erlang, and Apple's HeaderDoc.

Technical architecture

Structure of a Javadoc comment

A Javadoc comment is set off from code by standard multi-line comment tags /* and */. The opening tag (called begin-comment delimiter), has an extra asterisk, as in /**.

  1. The first paragraph is a description of the method documented.
  2. Following the description are a varying number of descriptive tags, signifying:
    1. The parameters of the method (@param)
    2. What the method returns (@return)
    3. Any exceptions the method may throw (@throws)
    4. Other less-common tags such as @see (a "see also" tag)

Overview of Javadoc

Most Javadoc comments are imbedded inside /** ... */ tags. The Javadoc comment block is positioned immediately above the itemswithout any separating newline, and below any import statements.The class declaration usuallycontains:

// import statements

/** * @author Firstname Lastname

* @version 1.6 (current version number of program) * @since 1.2 (the version of the package this class was first added to) */public class Test

Documentation comments for methods usually contain a short, concise, one line description toexplain what the item does, followed by a longer description, and lastly a tag section that lists accepted input arguments and return values of the method. TheJavadoc is treated as HTML, so a "<p>" paragraph break tag can be used to denote multiple paragraphs.

/** * Short one line description. (1) *

* Longer description. If there were any, it would be (2) * here. *

* And even more explanations to follow in consecutive * paragraphs separated by HTML paragraph breaks. * * @param variable Description text text text. (3) * @return Description text text text. */public int methodName (...)

Variables are documented similarly to methods, but often lack the tags at the end of the comment.

/** * Description of the variable here. */private int debug = 0;

It is not recommended[6] to define multiple variables in a single documentation comment, as Javadoc reads each variable and places them separately to the generated HTML page with the same documentation comment that is copied for all fields.

/** * The horizontal and vertical distances of point (x,y) */public int x, y; // AVOID

Instead, it is recommended to write and document each variable separately:

/** * The horizontal distance of point. */public int x;

/** * The vertical distance of point. */public int y;

Table of Javadoc tags

Some of the available Javadoc tags[7] are listed in the table below:

Tag & ParameterUsageApplies toSince
@author John SmithDescribes an author. Class, Interface, Enum
Represents the relative path to the generated document's root directory from any generated page.Class, Interface, Enum, Field, Method
@version versionProvides software version information. Module, Package, Class, Interface, Enum
@since since-textDescribes when this functionality has first existed. Class, Interface, Enum, Field, Method
@see referenceProvides a link to other element of documentation. Class, Interface, Enum, Field, Method
@param name descriptionDescribes a method parameter. Method
@return descriptionDescribes the return value. Method
@exception classname description
@throws classname description
Describes an exception that may be thrown from this method.Method
@deprecated descriptionDescribes an outdated method. Class, Interface, Enum, Field, Method
Copies the description from the overridden method.Overriding Method1.4.0
Link to other symbol.Class, Interface, Enum, Field, Method
Identical to, except the link's label is displayed in plain text than code font.Class, Interface, Enum, Field, Method
Return the value of a static field.Static Field1.4.0
Formats literal text in the code font. It is equivalent to <code>{@literal}</code>. || Class, Interface, Enum, Field, Method||1.5.0|-||| Denotes literal text. The enclosed text is interpreted as not containing HTML markup or nested javadoc tags. || Class, Interface, Enum, Field, Method||1.5.0|-||Used in the doc comment for a default serializable field.|Field||-||Documents the data written by the writeObject or writeExternal methods.|Field, Method||-||Documents an ObjectStreamField component.|Field||}

Examples

An example of Javadoc to document a method follows. Notice that spacing and number of characters in this example are as conventions state./** * Validates a chess move. * *

Use to move a piece. * * @param fromFile file from which a piece is being moved * @param fromRank rank from which a piece is being moved * @param toFile file to which a piece is being moved * @param toRank rank to which a piece is being moved * @return true if the move is valid, otherwise false * @since 1.0 */boolean isValidMove(int fromFile, int fromRank, int toFile, int toRank)

/** * Moves a chess piece. * * @see java.math.RoundingMode */void doMove(int fromFile, int fromRank, int toFile, int toRank)

Doclets

Doclet programs work with the Javadoc tool to generate documentation from code written in Java.[8]

Doclets are written in the Java programming language and use the to:

  • Select which content to include in the documentation
  • Format the presentation of the content
  • Create the file that contains the documentation

The https://docs.oracle.com/javase/9/javadoc/javadoc-command.htm#JSJAV-GUID-04BFA924-7C45-4E9C-91D1-0B77D97E65AB included with Javadoc generates API documentation as frame-based HTML files. Many non-standard doclets are available on the web, often for free. These can be used to:

  • Create other non-API types of documentation
  • Output the documentation to other non-HTML file types such as PDF
  • Output the documentation as HTML with additional features such as a search or with embedded UML diagrams generated from the Java classes

See also

External links

Notes and References

  1. Web site: Javadoc . agile.csc.ncsu.edu . 12 January 2022 . https://web.archive.org/web/20170613233020/http://agile.csc.ncsu.edu/SEMaterials/tutorials/javadoc/ . 13 June 2017 . dead.
  2. Web site: javadoc - The Java API Documentation Generator. 2011-09-30. Sun Microsystems. .
  3. https://www.jetbrains.com/idea/ IntelliJ IDEA
  4. Web site: How to Write Doc Comments for the Javadoc Tool. 2011-09-30. Sun Microsystems. .
  5. Web site: Visualizing with JavaDoc. Bill. Venners. James. Gosling . etal . artima.com. 2003-07-08. 2013-01-19. When I did the original JavaDoc in the original compiler, even the people close around me pretty soundly criticized it. And it was interesting, because the usual criticism was: a good tech writer could do a lot better job than the JavaDoc does. And the answer is, well, yeah, but how many APIs are actually documented by good tech writers? And how many of them actually update their documentation often enough to be useful?.
  6. News: Java Platform, Standard Edition Tools Reference for Oracle JDK on Solaris, Linux, and OS X, Release 8. Section "Multiple-Field Declarations". 20 Dec 2017.
  7. https://docs.oracle.com/en/java/javase/13/docs/specs/javadoc/doc-comment-spec.html JavaSE 13 Documentation Comment Specification
  8. Web site: Doclet Overview .