PDF de programación - JavaDoc. Comentando el código fuente.

Imágen de pdf JavaDoc. Comentando el código fuente.

JavaDoc. Comentando el código fuente.gráfica de visualizaciones

Publicado el 8 de Junio del 2019
778 visualizaciones desde el 8 de Junio del 2019
25,5 KB
7 paginas
Creado hace 22a (16/02/2002)
Javadoc (parte 1)

JavaDoc. Comentando el código fuente.

Este artículo es el inicio de una serie de ellos dedicados a aprender cómo comentar el código
Java y cómo generar la documentación HTML de nuestras API's mediante la herramienta de
generación automática Javadoc.

Como mi mentor en Java me dijo una vez, el buen código en Java se comenta solo y no le
falta razón. Por eso, aquí vamos a aprender que no es necesario comentar todas las líneas de
código (salvo algún caso excepcional que requiera ser remarcado por su importancia).
Realmente lo único necesario es comentar la clase y cada uno de los métodos que empleemos,
bien para quien quiera entender qué hace esa clase o la función que desenpeñan cada uno de
los métodos o bien, como es la intención de este artículo para que luego la herramienta de
generación automática de documentación nos cree la nuestra.

En este primer artículo nos dedicaremos a aprender cómo se comentan las clases y las
etiquetas que disponemos para añadir información adicional.


Tipo de comentario para generar la documentación.

A parte de los ya sabidos /* */ ó //, también tenemos un tercero propio de java y que es el que
usa el javadoc como delimitador para reconocer la documentación que tiene que generar.
Cualquier comentario de este tipo debe comenzar por el delimitador /** y, luego, cada línea
de comentario que añadamos debe seguir al operador *. Así mismo, también comenzarán por
un * las etiquetas, sólo que éstas a su vez deben ser precedidas por el operador @ como se
verá en el próximo
capítulo.

Una cosa muy importante que quiero resaltar ya es que javadoc lo único que hace es copiar el
contenido a una página HTML por lo que se admite cualquier etiqueta HTML que queráis
para darle más claridad o vistosidad a vuestra documentación. Vemos a continuación el
formato típico de un comentario al estilo javadoc.

/**
* Al usar este estilo de comentario estoy consiguiendo que cuando
* lo pase por javadoc, esta herramienta copie este texto a una página
* html.
* Puedes ver que también admite <b>etiquetas HTML</b>
* y ésto último que acabo de escribir aparecerá en negrita.
*/

Las etiquetas.

Aparte de los comentarios propios, la utilidad javadoc nos proporciona una serie de etiquetas
para completar la información que queremos dar de una determinada clase o método. Son las
siguientes:

@author nombre (desde la versión 1.0 del JDK/SDK)

1

http://www.javahispano.com

Indica el autor de la clase en el argumento nombre. Un comentario de este tipo puede tener
más de un autor en cuyo caso podemos usar tantas etiquetas de este tipo como autores hayan
colaborado en la creación del código fuente o bien podemos ponerlos a todos en una sola
etiqueta. En éste último caso, Javadoc inserta una (,) y un espacio entre los diferentes
nombres.


@deprecated comentario (desde la versión 1.0 del JDK/SDK)

Añade un comentario indicando que este API no debería volver a usarse, aunque aun siga
perteneciendo a la distribución del SDK que estemos utilizando, por estar desautorizado o
"desfasado". No obstante, ésto es sólo una advertencia que nosotros damos a los usuarios de
nuestras API's, al igual que las distribuciones de Sun hacen con nosotros. Realmente, lo que
estamos haciendo al decir que una determinada API está desfasada es prevenir de que en un
futuro podrán surgir incompatibilidades si seguimos usándolas ya que éste es el paso a previo
a la desaparición del API en concreto.

En la primera frase del comentario, que es la que la documentación nos la muestra en la
sección del resumen de nuestra clase, deberíamos como mínimo poner desde que versión de
nuestra API está desautorizada y por quién se debería sustituir. A partir de Java 1.2 podemos
usar {@link} para referenciar por quién debemos hacer la sustitución.


@exception nombre-clase descripción (desde la versión 1.0 del JDK/SDK)

Esta etiqueta actúa exactamente igual que @throws.


{@link nombre etiqueta} (desde la versión 1.2 del JDK/SDK)

Inserta un enlace autocontenido que apunta a nombre. Esta etiqueta acepta exactamente la
misma sintáxis que la etiqueta @see, que se describe más abajo, pero genera un enlace
autocontenido en vez de colocar el enlace en la sección "See Also". Dado que esta etiqueta
usa los carácteres { } para separarla del resto del texto in-line, si necesitas emplear el caracter
"}" dentro de la etiqueta debes usar la notación HTML &#125;

No existe ninguna limitación en cuanto al número de etiquetas de este tipo permitidas. Puedes
usarlas tanto en la parte de la descripción como en cualquier porción de texto de cualquier
otra etiqueta de las que nos proporciona JavaDoc.

En el siguiente ejemplo, vemos como crear dentro de nuestra documentación un enlace in-line
al método getComponentAt(int, int).

@deprecated Desde JDK1.1 Usar el método {@link #getComponentAt(int, int)
getComponentAt}

A partir de esta descripción, la herramienta de generación automática de código generará el
siguiente código HTML (supone que se está refiriendo a una clase del mismo paquete):

Usar el método <a href="Component.html#getComponentAt(int,
int)">getComponentAt</a> , el cual aparecerá en la página HTML como:

2

Javadoc (parte 1)

Usar el método getComponentAt


@param parámetro descripción (desde la versión 1.0 del JDK/SDK)

Añade un parámetro y su descripción a la sección "Parameters" de la documentación HTML
que generará. Por tanto, para cada método emplearemos tantas etiquetas de este estilo como
parámetros de entrada tenga dicho método.


@return descripción (desde la versión 1.0 del JDK/SDK)

Añade a la sección "Returns" de la documentación HTML que va a generar la descripción del
tipo que devuelve el método. Veámos el siguiente ejemplo:

Si suponemos que tenemos el método public String concatena(String s1, String
s2, String s3) deberíamos comentar nuestro código fuente de la siguiente manera:

/*
* ....
* @param s1 Texto que ocupa la cabecera
* @param s2 Texto que ocupa el cuerpo de la string a crear
* @param s3 Texto que ocupa la parte final
* @return La cadena conformada de tipo String.
*/


@see referencia (desde la versión 1.0 del JDK/SDK)

Añade un cabecero "See Also" con un enlace o texto que apunta a una referencia. El
comentario de la documentación puede contener cualquier número de etiquetas de este tipo y
todas, al generar la documentación, se agruparán bajo el mismo cabecero. Esta etiqueta se
puede conformar de tres maneras diferentes, siendo la última forma la más utilizada.


@see "string"

En este caso, no se genera ningún enlace. La string es un libro o cualquier otra
referencia a una información que no está disponible via URL. JavaDoc distingue este
caso buscando en el primer carácter de la cadena las comillas dobles ("). Por ejemplo:

@see "The Java Programming Language"
que genera el siguiente texto HTML:

See Also:
"The Java Programming Language"
@see <a href="URL#value">label</a>

Añade un enlace definido por URL#value. Esta dirección puede ser relativa o
absoluta. JavaDoc distingue este caso buscando en el primer carácter el símbolo "<".
Por ejemplo:

@see <a href="spec.html#section">Java Spec</a>
que genera el siguiente enlace:

See Also:
Java Spec

@see package.class#member texto

3

http://www.javahispano.com

Añade un enlace, con el texto visible texto, que apunta en la documentación al nombre
especificado en el lenguaje Java al cual hace referencia. Aquí por nombre se debe
entender un paquete, una clase, un método o un campo. El argumento texto es
opcional, si se omite, JavaDoc nos dará la información mínima, ésto es, el nombre de,
por ejemplo, la pareja paquete#método. Usa este campo cuando quieras especificar
algo más, cuando quieras representarlo por un nombre más corto o simplemente si
quieres que aparezca con otro nombre. Veámos a continuación varios ejemplos usando
la etiqueta @see.



Nota: El comentario a la derecha muestra cómo aparecerá la etiqueta en las especificaciones
HTML si la referencia a la que apunta estuviera en otro paquete distinto al que estamos
comentando.
See also:
@see java.lang.String //
String
@see java.lang.String The String class // The String
class
@see String //
String
@see String#equals(Object) //
String.equals(Object)
@see String#equals //
String.equals(java.lang.Object)
@see java.lang.Object#wait(long) //
java.lang.Object.wait(long)
@see Character#MAX_RADIX //
Character.MAX_RADIX
@see <a href="spec.html">Java Spec</a> // Java Spec
@see "The Java Programming Language" // "The Java Programming
Language"


@since texto (desde la versión 1.1 del JDK/SDK)

Indica con texto desde cuándo se creó este paquete, clase o método. Normalmente se pone la
versión de nuestra API en que se incluyó, así en posteriores versiones sabremos a qué revisión
pertenece o en qué revisión se añadió. Por ejemplo:

@since JDK1.1


@serial field-description (desde la versión 1.2 del JDK/SDK)

Su uso está destinado a señalar un campo serializable. Por defecto, todos los campos
(variables) son susceptibles de ser serializados lo cual no quiere decir que nuestra aplicación
lo tenga que hacer. Por tanto, úsala sólo cuando tengas una variable serializable. Aprovecho
para decirte que no te asustes si tu clase tiene, digamos, 20 variables y al generar la
documentación HTML te "cantan" 20 warnings. Ésto ocurre porque JavaDoc esperaba que
hubieras asignado una etiqueta serial a cada una de tus variables ya que como dije antes, en
principio todas estas variables pueden ser serializables. En fin, la 2ª vez que generes
  • Links de descarga
http://lwp-l.com/pdf16067

Comentarios de: JavaDoc. Comentando el código fuente. (0)


No hay comentarios
 

Comentar...

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad