Download javadoc
Document related concepts
no text concepts found
Transcript
Documentación en Java: Javadoc Programación 2 – Curso 2011/2012 Juan Manuel Gimeno José Luis González La documentación de Java • Tanto la biblioteca estándar de Java como la de la ACM sn muy extensas – Multitud de clases – Multitud de métodos • Es imposible conocerlos todos con detalle suficiente como para utilizarlos correctamente • Por ello es muy importante disponer de una muy buena documentación. La documentación de Java • Es por ello que los diseñadores de Java, definieron un método sencillo para generar la documentación de las clases y métodos: – La documentación se inserta en el mismo fichero que el código (en forma de comentarios) • De esta manera es más fácil que evolucione con él – La herramienta javadoc extrae esos comentarios especiales y genera páginas html para ser vistas desde el navegador • De esta manera facilitamos poder navegar de una clase a otra. Accediendo a la documentación • Como cuando configuramos las bibliotecas de la ACM añadimos el javadoc, podemos acceder a él a partir del apartado bibliotecas de nuestro proyecto • También podemos acceder a las de la biblioteca de Java Añadiendo comentarios javadoc • Añadir documentación es tan simple como poner un comentario que empiece por /** y acabe con */ • Para poder estructurar mejor los comentarios dentro del comentario usaremos las marcas @param y @return para describir con detalle los parámetros y el resultado. • Hay muchas marcas interesantes como por ejemplo @author, @version, @since, @throws, etc. Cómo generarlo • Generar la documentación en Netbeans es tan fácil como, desde el proyecto, marcar en el menú contextual la opción “Generar javadoc” • Una vez generada, nos abrirá el navegador para acceder a ella. Accediendo al javadoc • Los ficheros generados los encontraréis en el subdirectorio dist/javadoc dentro del proyecto. Netbeans 7 y el paquete por defecto • Como ya sabéis, cuando creamos una clase, aunque el Netbeans indica que no es recomendable, lo hacemos en el paquete por defecto • Hasta ahora esto no daba problemas, pero a partir de la versión 7, Netbeans no genera documentación para las clases del paquete por defecto • Por eso, a partir de ahora, crearemos un paquete para todas las clases del proyecto Creando una clase en un paquete En vez de dejarlo en blanco añadimos un nombre para el paquete El nombre del paquete se convierte en una subcarpeta dentro de la carpeta que contiene los ficheros java La clase ahora pertenece al paquete Cómo mover una clase a un paquete Si hemos definido una clase en el paquete por defecto la podemos mover a otro paquete. La clase principal ha de referenciar el paquete al que pertenece Error en algunas plataformas • En algunas combinaciones de sistema operativo y versión de java, si ponemos la clase del programa principal en un paquete, al ejecutar obtenemos un error similar a: Exception in thread "main" java.lang.UnsatisfiedLinkError: acm.util.DOSCommandLine.getLine()Ljava/lang/String; at acm.util.DOSCommandLine.getLine(Native Method) at acm.util.DOSCommandLine.getCommandLine(JTFTools.java:1627) at acm.util.JTFTools.getCommandLine(JTFTools.java:439) at acm.util.JTFTools.getMainClass(JTFTools.java:464) at acm.program.Program.main(Program.java:1320) Error en algunas plataformas • El problema es que el mecanismo que usa la biblioteca JTF para iniciar la ejecución de un programa es incapaz de encontrar el método main • Por ello lo que haremos será incluir explícitamente un método main que funcione igual que el que proporciona la biblioteca Error en algunas plataformas • Para ello añadiríamos en la clase que representa el programa principal un método main como el siguiente: package example; import acm.program.ConsoleProgram; public class StudentTest extends ConsoleProgram { public void run() { .... } public static void main(String[] args) { new StudentTest().start(args); } }