Документирование кода java, создание документации с помощью утилиты javadoc

Документирование кода

Рассмотрим документирование кода. Мы изучим технологию создания документации с помощью утилиты javadoc. В листинге 5.5 представлен пример простого документирования кода.

Листинг 5.5.
Пример документирования кода

/**
 * Created by vitaly on 29.05.2016.
 */
public class Fruits {
    /** Свойство - цвет */
    String color;
    /** Свойство - имя */
    String name;
    /** Создает новый объект без задания значения свойства color */
    public Fruits() {

    }
    public Fruits(String name) {
        this.name = name;
    }
    /** Создает объект с заданием ему всех свойств */
    public Fruits(String name, String color) {
        this.name = name;
        this.color = color;
    }
    /** Задает значение свойства name */
    public void setName(String name) {
        this.name = name;
    }
    /** Получает значение свойства name */
    public String getName() {
        return name;
    }
    /** Задает значение свойства color */
    public void setColor(String color) {
        this.color = color;
    }
    /** Получает значение свойства color */
    public String getColor() {
        return color;
    }
    /** Главный метод программы. Создает 3 объекта: apple, orange и lemon и устанавливает для них значения свойств, а затем выводит на экран */
    public static void main(String[] args) {
        Fruits apple = new Fruits();
        apple.setName("Apple");
        apple.setColor("Red");

        Fruits orange = new Fruits("Orange");
        orange.setColor("Orange");

        Fruits lemon = new Fruits("Lemon", "Yellow");

        System.out.println("Значение объекта apple:\nname = " + apple.name + "\ncolor = " + apple.color + "\n");
        System.out.println("Значение объекта orange:\nname = " + orange.name + "\ncolor = " + orange.color + "\n");
        System.out.println("Значение объекта lemon:\nname = " + lemon.name + "\ncolor = " + lemon.color + "\n");
    }
}

В комментариях нужно использовать теги, иначе javadoc откажется правильно работать. Они предназначены для специфического отображения текста. Все теги начинаются с символа @.

Давайте рассмотрим некоторые из них.

2016-05-29_09-34-29

Приведем пример уже созданной программы с документированием кода с помощью тегов (листинг 5.6).

Листинг 5.6.
Пример программы с документированием кода с помощью тегов

/** Класс служит для хранения объектов-фруктов со свойствами
 <b>name</b> и <b>color</b>
 @author vitaly
 @version 1.0
 */
public class Fruits {
    /** Свойство - цвет */
    String color;
    /** Свойство - имя */
    String name;
    /** Создает новый объект
     @see Fruits#Fruits(String)
     @see Fruits#Fruits(String, String)
     */
    public Fruits() {

    }
    /** Создает новый объект
     @param name Имя фрукта
     @see Fruits#Fruits()
     @see Fruits#Fruits(String, String)
     */
    public Fruits(String name) {
        this.name = name;
    }
    /** Создает новый объект
     @param name Имя фрукта
     @param color Цвет фрукта
     @see Fruits#Fruits()
     @see Fruits#Fruits(String)
     */
    public Fruits(String name, String color) {
        this.name = name;
        this.color = color;
    }
    /** Задает значение свойства name, которое можно получить при помощи метода {@link #getName()}
     @param name Новое значение свойства name
     */
    public void setName(String name) {
        this.name = name;
    }
    /** Получает значение свойства name, которое можно задать с помощью метода {@link #setName(String)}
     @return Значение свойства name
     */
    public String getName() {
        return name;
    }
    /** Задает значение свойства color, которое можно получить при помощи метода {@link #getColor()}
     @param color Новое значение свойства color
     */
    public void setColor(String color) {
        this.color = color;
    }
    /** Получает значение свойства color, которое можно задать с помощью метода {@link #setColor(String)}
     @return Значение свойства color
     */
    public String getColor() {
        return color;
    }
    /** Главный метод программы. Создает 3 объекта: apple, orange и lemon и устанавливает для них значения свойств, а затем выводит на экран
     @params args Параметры командной строки
     */
    public static void main(String[] args) {
        Fruits apple = new Fruits();
        apple.setName("Apple");
        apple.setColor("Red");

        Fruits orange = new Fruits("Orange");
        orange.setColor("Orange");

        Fruits lemon = new Fruits("Lemon", "Yellow");

        System.out.println("Значение объекта apple:\nname = " + apple.name + "\ncolor = " + apple.color + "\n");
        System.out.println("Значение объекта orange:\nname = " + orange.name + "\ncolor = " + orange.color + "\n");
        System.out.println("Значение объекта lemon:\nname = " + lemon.name + "\ncolor = " + lemon.color + "\n");
    }
}

 

< Предыдущая       Оглавление       Следующая >

Коментарі: 6
  1. Зачем это нужно?

    1. Виталий Непочатов
      admin (автор)

      Для документирования кода

  2. Для новичка абсолютно непонятная статья. Пришлось искать информацию в других источниках.

  3. Сергей

    похоже Runnable и Thread одинаковы, или только я вижу их такими? как исправите, удалите мой комментарий

    1. Виталий Непочатов
      admin (автор)

      спасибо, исправили и вывели в отдельный урок http://www.fandroid.info/chto-takoe-mnogopotochnost-rabota-s-potokami-v-java/

Додати коментар