Proyectos Java Package Import Visibilidad Clases Ejemplos
Proyectos Java Package Import Visibilidad Clases Ejemplos
Proyectos Java Package Import Visibilidad Clases Ejemplos
PROYECTOS JAVA.
CLUSULAS PACKAGE E
IMPORT. JERARQUA Y
APRENDERAPROGRAMAR.COM
VISIBILIDAD DE CLASES.
ORGANIZACIN EN BLUEJ.
EJEMPLOS. (CU00674B)
Seccin: Cursos
Categora: Curso Aprender programacin Java desde cero
Los proyectos (en general podramos establecer equivalencia de proyecto con programa, pero no
siempre es as; proyecto es un conjunto de cdigo que se mantiene agrupado) en Java se suelen
organizar en paquetes (packages). El concepto de paquete viene siendo similar al de carpeta en
Windows: un contenedor donde mantenemos cosas relacionadas entre s.
De hecho, en entornos como Eclipse o BlueJ esto es exactamente as: al crear packages, veremos que
creamos una carpeta. No obstante, la organizacin en packages tiene muchas ms implicaciones como
veremos a continuacin.
La organizacin del proyecto ser por tanto similar a la organizacin de archivos: en un paquete
podremos tener por ejemplo clases de tipo A, en otro clases de tipo B y as sucesivamente. A su vez, un
paquete puede contener subpaquetes: por ejemplo el paquete A puede contener a los subpaquetes
A.1, A.2 y A.3. Un package es una agrupacin de clases afines. Recuerda el concepto de librera
existente en otros lenguajes o sistemas.
Una clase puede definirse como perteneciente a un package y puede usar otras clases definidas en ese
o en otros packages. Los packages delimitan el espacio de nombres (space name). El nombre de una
clase debe ser nico dentro del package donde se define. Dos clases con el mismo nombre en dos
packages distintos pueden coexistir e incluso pueden ser usadas en el mismo programa. Una clase se
declara perteneciente a un package con la clusula package incluida como una lnea de cdigo, cuya
sintaxis es: package nombrePackage;. La clusula package debe ser la primera sentencia del cdigo
fuente. Por ejemplo, una clase puede comenzar as:
package miPackage;
...
public class miClase {
...
Este cdigo implica que la clase miClase pertenece al package miPackage. La clusula package es
opcional. Si no se utiliza, las clases declaradas en el archivo fuente no pertenecen a ningn package
concreto, sino que pertenecen a un package por defecto (sin nombre). La agrupacin de clases en
packages es conveniente desde el punto de vista organizativo, para mantener bajo una ubicacin
comn clases relacionadas que cooperan desde algn punto de vista. Tambin resulta importante por
la implicacin que los packages tienen en la visibilidad y acceso del cdigo entre distintas partes de un
programa. Cuando se referencia cualquier clase dentro de otra se asume, si no se indica otra cosa, que
sta otra est declarada en el mismo package. Por ejemplo:
aprenderaprogramar.com, 2006-2029
Proyectos Java en paquetes (Packages).
package Directivos;
...
public class JefeDeAdministracion { //Ejemplo aprenderaprogramar.com
private Persona jefeAdmin;
...
}
package TiposBasicos;
public class Persona {
private String nombre;
}
Entonces, para usar la clase Persona en nuestra clase JefeDeAdministracion deberamos poner:
package Directivos;
import TiposBasicos.*;
class JefeDeAdministracion {
private Persona jefeAdmin;
...
}
Con la clusula import TiposBasicos.*; se hacen accesibles todas las clases declaradas en el package
TiposBasicos. Si slo se quisiera tener accesible la clase Persona se podra declarar: import
TiposBasicos.Persona;. Tambin es posible hacer accesibles los nombres de un package sin usar la
clusula import calificando completamente los nombres de aquellas clases pertenecientes a otros
packages. Por ejemplo:
package Directivos;
class JefeDeAdministracion { //Ejemplo aprenderaprogramar.com
private TiposBasicos.Persona jefeAdmin;
...
}
Sin embargo si no se usa import es necesario especificar el nombre del package cada vez que se usa el
tipo Persona, lo cual puede resultar un tanto engorroso. La clusula import en esta acepcin
simplemente indica al compilador dnde debe buscar clases adicionales cuando no pueda encontrarlas
en el package actual y delimita los espacios de nombres y modificadores de acceso. Sin embargo, no
tiene la implicacin de 'importar' o copiar cdigo fuente u objeto alguno. En una clase puede haber
tantas sentencias import como sean necesarias. Las clusulas import se colocan despus de la clusula
package (si es que existe) y antes de las definiciones de las clases.
aprenderaprogramar.com, 2006-2029
Proyectos Java en paquetes (Packages).
Los packages se pueden nombrar usando nombres compuestos separados por puntos, de forma similar
a como se componen las llamadas a los mtodos. Por ejemplo se puede tener un package de nombre
tiposBasicos.directivos. Cuando se utiliza esta estructura se habla de packages y subpackages. En el
ejemplo tiposBasicos es el Package base, directivos es un subpackage y a su vez podran existir otros
subpackages de directivos. De esta forma se pueden tener los packages ordenados segn una jerarqua
equivalente a un sistema de archivos jerrquico. El API de Java est estructurado de esta forma, con un
primer calificador (java o javax) que indica la base, un segundo calificador (awt, util, swing, etc.) que
indica el grupo funcional de clases y opcionalmente subpackages en un tercer nivel, dependiendo de la
amplitud del grupo. Por ejemplo en java.util.ArrayList<E>, java sera el package bsico, util un
subpackge y ArrayList una clase. Cuando se crean packages de usuario no es recomendable usar
nombres de packages que empiecen por java o javax para evitar confusiones con los propios del API de
Java.
Adems del significado lgico descrito hasta ahora, los packages tambin tienen un significado fsico al
servir para almacenar los ficheros con extensin .class en el sistema de archivos del ordenador.
Supongamos que definimos una clase de nombre miClase que pertenece a un package de nombre
gestorDePersonal.tiposBasicos.directivos. Cuando la JVM vaya a cargar en memoria miClase buscar el
mdulo ejecutable (de nombre miClase.class) en un directorio en la ruta de acceso
gestorDePersonal/tiposBasicos/directivos (esta ruta de acceso estar definida a partir del directorio raz
para la JVM). Est ruta deber existir y estar accesible a la JVM para que encuentre las clases.
Si una clase no pertenece a ningn package (no existe clusula package) se asume que pertenece a un
package por defecto sin nombre, y la JVM buscar el archivo .class en el directorio que use como raz.
Para que una clase pueda ser usada fuera del package donde se defini debe ser declarada con el
modificador de acceso public. Por ejemplo:
package Directivos;
public class JefeDeAdministracion {
private Persona jefeAdmin;
...
}
Si una clase no se declara public slo puede ser usada por clases que pertenezcan al mismo package.
Consideremos un proyecto en BlueJ. Hasta ahora lo hemos visto como algo as:
aprenderaprogramar.com, 2006-2029
Proyectos Java en paquetes (Packages).
Aqu veamos las clases y disponamos del botn New Class para ir aadiendo clases. En qu package
estn estas clases? En el package por defecto (sin nombre), asociado al directorio raz donde hayamos
guardado el proyecto. Supongamos ahora que nuestra organizacin fuera que la clase
EntradaPorTeclado perteneciera a un package denominado entradas.usuarios, es decir, que la clase
perteneciera al subpaquete usuarios del paquete entradas. Para crear los paquetes pulsamos en el
men Edit -> New package, y escribimos el nombre del package base, esto es, entradas. Nos aparece
un icono entradas y haciendo doble click sobre l se nos abre la ventana del package creado:
Donde el icono tipo carpeta go up nos sirve para subir de nivel en la jerarqua de packages. Situados
en la ventana del package entradas repetiremos la operacin creando el package usuarios. Ahora desde
el package entradas podemos hacer dos cosas: subir de nivel hacia la raz, o profundizar nivel hacia
usuarios. Si comprobamos nuestro sistema de archivos, veremos cmo se han ido creando carpetas
anidadas que de momento slo contienen un archivo package.BlueJ. Adems, si entramos en el package
usuarios y vemos lo que nos indica la ventana de BlueJ, aparece [entradas.usuarios], es decir, por
defecto nos est estableciendo la ruta de packages con notacin de puntos (muy al estilo de Java). En el
nivel raz, borremos ahora el package entradas. Nos aparecer una advertencia indicndonos que si
borramos el package eliminaremos de forma permanente el directorio asociado al package incluyendo
todos los contenidos de ese directorio (esto tiene su peligro pues podramos borrar carpetas
accidentalmente). Aceptemos y vayamos al sistema de archivos. Veremos cmo las carpetas
correspondientes a packages y subpackages han desaparecido.
Existe una forma abreviada de definir estructuras de packages. Cuando empezamos un proyecto es
posible que ya hayamos pensado cmo vamos a organizarlo. Podemos definir de forma directa una
estructura usando, desde el nivel raz, la creacin de un package con la notacin de puntos. BlueJ crear
de forma automtica las carpetas y subcarpetas necesarias. Por ejemplo, lo mismo que hicimos antes
en dos pasos (primero crear el package entradas y luego crear el package usuario), podemos hacerlo
dndole a Edit -> New package, y escribiendo la jerarqua o ruta de packages: en nuestro caso
escribimos entradas.usuarios. De esta manera, BlueJ nos crea automticamente los packages anidados
y las carpetas y subcarpetas correspondientes.
aprenderaprogramar.com, 2006-2029
Proyectos Java en paquetes (Packages).
Al haber eliminado una clase (que hemos puesto en un package) hay que compilar de nuevo. Y al
compilar nos salta el error: cannot find symbol class entradaPorTeclado. Qu ocurre? Que el que la
clase se encuentre en un package afecta a su visibilidad. En este caso la clase TestPseudoAleatorios no
puede ver a la clase EntradaDeTeclado. Vamos a solucionarlo con una importacin a la clase
aprenderaprogramar.com, 2006-2029
Proyectos Java en paquetes (Packages).
TestPseudoAleatorios no aparece conectado con una flecha de relacin de uso con el package entradas.
Por qu? Porque la flecha se reserva para relaciones de uso directo de una clase a otra dentro de un
mismo paquete. Cuando se trata de usos a travs de import no nos aparece de forma explcita la
representacin de dicha relacin.
Una ltima cuestin: ni los paquetes superiores reconocen las clases de los subpaquetes ni al revs:
aqu, en principio, nadie conoce a nadie. Por tanto tambin hemos de importar las clases o paquetes
incluso desde paquetes que estn jerrquicamente en la misma lnea y por encima de otros paquetes.
EJERCICIO
a) Un package denominado formas dentro del cual existan los siguientes packages: formas1dimension,
formas2dimensiones y formas3dimensiones.
b) Dentro del package formas1dimension deben existir las clases Recta y Curva.
c) Dentro del package formas2dimensiones deben existir las clases Triangulo, Cuadrilatero,Elipse,
Parabola e Hiperbola.
d) Dentro del package formas3dimensiones deben existir las clases Cilindro, Cono y Esfera.
Nota: crea las clases sin rellenar su cdigo, simplemente para poder visualizar que estn dentro de los
packages adecuados.
Visualiza el resultado y comprueba que las clases estn agrupadas de forma adecuada.
aprenderaprogramar.com, 2006-2029