Tema 5 Genericidad y Colecciones. Programación Orientada a Objetos Curso 2015/2016

Documentos relacionados
Tema 4 Colecciones en Java. Programación Orientada a Objetos Curso 2013/2014

Tema 4 Genericidad. Programación Orientada a Objetos Curso 2010/2011

Colecciones e iteradores

Tema 4 Genericidad en Java. Programación Orientada a Objetos Curso 2013/2014

8. Colecciones e iteradores

Tema 4 Genericidad y Colecciones. Programación Orientada a Objetos Curso 2016/2017

Computación Geométrica Colecciones en Java

Centro Asociado Palma de Mallorca. Antonio Rivero Cuesta

Centro Asociado Palma de Mallorca. Antonio Rivero Cuesta

Tema 3: Herencia en C# Programación Orientada a Objetos Curso 2008/2009 Begoña Moros Valle

Tema 6 Patrones de Diseño. Programación Orientada a Objetos Curso 2010/2011

Examen Teórico Convocatoria de Junio de 2012

Tema 3 Herencia en Java Parte 2. Programación Orientada a Objetos Curso 2015/2016

Federico Peinado

Tema 3. Repaso de primero Análisis y Diseño de Algoritmos

Programación Tema 9: Bibliotecas y Colecciones. Programación DIT-UPM

Patrones de Diseño. Patrón de comportamiento Iterator. Técnicas de Programación - Curso 2007/08

Patrones de Diseño. Patrón de comportamiento Iterator. Técnicas de programación - Curso 2008/09 (Esther Guerra Sánchez)

Interfaces. Amparo López Gaona. Septiembre de Amparo López Gaona () Interfaces Septiembre de / 1

Colecciones. Interfaces para colecciones. Beneficios de utilizar el marco de colecciones. Interfaces para colecciones

Tema 3 Herencia en Java Parte 2. Programación Orientada a Objetos Curso 2015/2016

Interface nominterface{

Ejercicio 1 (proyecto prlistas, paquete listas)

Lenguaje Java. Sesión 2: Colecciones de datos. Experto Universitario en Desarrollo de Aplicaciones para Dispositivos Móviles

Unidad Didáctica 6. Tipos List y Set con tipos genéricos. Fundamentos de Programación Departamento de Lenguajes y Sistemas Informáticos. Versión 1.0.

INTERFACE COLLECTION DE JAVA.UTIL DEL API JAVA. EJERCICIOS Y EJEMPLOS RESUELTOS. MÉTODOS ADD, REMOVE, SIZE. STREAMS (CU00917C)

Definición de framework. Razonamiento Geométrico. El framework de colecciones de Java 1.2. Ejemplos de frameworks. Qué se define en un framework?

Examen Teórico. Convocatoria de Febrero de 2015

Algoritmos y Estructuras de Datos Iteradores. Guillermo Román Díez

Tema 3. Tipos List y Set

Colecciones de Java LSUB. 17 de febrero de 2016 GSYC

Examen Teórico. Convocatoria de Julio de 2015

Clases abstractas e interfaces en Java

EL PAQUETE JAVA.UTIL DEL API JAVA. PRINCIPALES INTERFACES Y CLASES: STRINGTOKENIZER, DATE, CALENDAR, HASHSET, TREEMAP, TREESET...

Ingeniería en Computación, Universidad de La Serena. import java.io.*; import java.util.linkedlist;

Programación II 2do cuatrimestre 2017

Estructuras de Datos Clase 7 Listas e Iteradores (segunda parte)

ARREGLOS Y COLECCIONES. Capítulo 7

Colecciones de Java LSUB. 30 de enero de 2013 GSYC

Examen de Estructuras de Datos y Algoritmos (Ingeniería Informática)

Programación orientada a objetos

Fundamentos de Programación

PROGRAMACIÓN GENÉRICA

INTERFACES SET Y SORTEDSET DEL API DE JAVA. CLASES HASHSET Y TREESET. EJEMPLO. DIFERENCIAS ENTRE ELLAS. (CU00924C)

PROGRAMACIÓN ORIENTADA A OBJETOS

ANEXO II: Resumen de uso de colecciones

Tema 3 Herencia. Primera parte. Herencia en Java Programación Orientada a Objetos Curso 2010/2011

EJERCICIO Y EJEMPLO RESUELTO: USO DE LA INTERFACE ITERABLE DEL API DE JAVA Y MÉTODO ITERATOR. RECORRER COLECCIONES DE OBJETOS (CU00915C)

PROGRAMACIÓN ORIENTADA A OBJETOS PROGRAMACIÓN ORIENTADA A OBJETOS. [W1H3] Array de elementos atomicos. [W3H2] Array de objetos

Construcciones del Lenguaje Java

Estructuras de datos y algoritmos

Estructuras de datos y algoritmos

Examen Teórico. Convocatoria de Febrero de 2016

Examen Teórico. Convocatoria de Febrero de 2018

INTERFACE LIST DEL API JAVA. CLASES ARRAYLIST, LINKEDLIST, STACK, VECTOR. EJEMPLO CON ARRAYLIST. (CU00920C)

PROGRAMACIÓN ORIENTADA A OBJETOS 10/02/2009. Examen de Java. Nombre: DNI: Titulación:

ÍNDICE DEL LIBRO Y DEL EBOOK APRENDER A PROGRAMAR EN JAVA DESDE CERO. CURSO PASO A PASO.

Arrays, Cadenas y Vectores Tipos Genéricos

Java Collections List vs Set (I)

INTERFACE ITERATOR DEL API JAVA. MÉTODO REMOVE PARA BORRAR OBJETOS EN COLECCIONES. EJERCICIOS Y EJEMPLO RESUELTO. (CU00919C)

Programación Orientada a Objetos Curso 2015/2016. Ejercicios sobre colecciones y Java 8

Algoritmos y Estructuras de Datos: Ordenación y Colas con Prioridad. Guillermo Román Díez

Ejercicio de Programación Orientada a Objetos Curso 2016/2017 Exámenes

ESTRUCTURA DE DATOS Y ALGORITMOS Titulación: Ingeniero Técnico en Informática de Gestión Curso: 2º Nombre y apellidos: Nota:

INTERFACES MAP Y SORTEDMAP DEL API JAVA. CLASES HASHMAP Y TREEMAP. EJEMPLO. DIFERENCIAS ENTRE ELLAS. (CU00922C)

Colecciones. Nadjet Bouayad-Agha Programación 2007

Programación orientada a objetos

Unidad Didáctica 3. Tipos genéricos. Fundamentos de Programación Departamento de Lenguajes y Sistemas Informáticos

Introducción a Java. Fernando Cerezal López. 24 Noviembre 2005

Diseño de tipos Igualdad, representación, código, copia y relación de orden

fundamentos de programación (unidad 7) herencia y relaciones entre clases

PROGRAMACIÓN ORIENTADA A OBJETOS 1/7/2009. Examen de Java. Nombre: DNI: Titulación:

Introducción a Generics y Collections

Tema 1. Herencia y Polimorfismo

Unidad Didáctica 2. Elementos básicos del lenguaje Java Tipos, declaraciones, expresiones y asignaciones

Bloque II. Elementos del lenguaje de programación Java

Tema 3 Herencia en Java Parte 1. Programación Orientada a Objetos Curso 2015/2016

Fundamentos de Informática

ESTRUCTURA DE DATOS Y ALGORITMOS Titulación: Ingeniero Técnico en Informática de Gestión Curso: 2º Nombre y apellidos: Nota:

Unidad Didáctica 19. Tratamientos Secuenciales Generalizados II. Versión 1.0.0

Entiendo los métodos de Java equals y hashcode

Tema 6 Java 8. Programación Orientada a Objetos Curso 2015/2016

Programación de sistemas Listas enlazadas

1.2. Es Java un lenguaje ideal para aprender a programar? 1.4. Cuáles son las versiones y distribuciones Java y cuál usar?

El programa P1 tiene como objetivo imprimir cada uno de los caracteres de una cadena en una línea, como por ejemplo: h o l a

IN77J Orientación al Objeto para el e-business. 2. Fundamentos de la OOP

Clase 33. Marco para las colecciones de Java. Historia

A3F. Polimorfismo. Carlos Fontela

Tema 2: Clases y Objetos en Java. Programación Orientada a Objetos Curso 2010/2011

Lenguajes de Programación Curso Práctica 4. Herencia. Utilización de interfaces y clases abstractas. 1. Interfaces Clases abstractas 2

Tema 3: Genericidad en Java. Tema 3: Genericidad en Java. Objetivos y Bibliografía. Modelos de Datos Genéricos

INDICE DEL CURSO APRENDER PROGRAMACIÓN JAVA DESDE CERO. PROGRAMACIÓN ORIENTADA A OBJETOS (CU00601B)

Práctica 2. Reutilización de código Elementos básicos del lenguaje Java Definición de variables, expresiones y asignaciones

Prácticas de Programación

Grado en Ingeniería Informática Estructura de Datos y Algoritmos, Grupo 80M, 2014/ de Marzo de

Tema 2.- Objetos y mensajes

Programación en Java. Instructor:

Transcripción:

Tema 5 Genericidad y Colecciones Programación Orientada a Objetos Curso 2015/2016

Contenido Parte I Genericidad: Definición de clases genéricas. Declaración y construcción de tipos genéricos. Genericidad restringida. Genericidad y herencia. Genericidad y sistema de tipos. Genericidad y máquina virtual. Métodos genéricos. Curso 2015/2016 Programación Orientada a Objetos 2

Genericidad Facilidad de un lenguaje de programación para definir clases, interfaces y métodos parametrizados con tipos de datos. Resultan de utilidad para la implementación de tipos de datos contenedores como las colecciones. La genericidad sólo tiene sentido en lenguajes con comprobación estática de tipos, como Java. La genericidad permite escribir código reutilizable. Curso 2015/2016 Programación Orientada a Objetos 3

Genericidad Una clase genérica es una clase que en su declaración utiliza un tipo variable (parámetro), que será establecido cuando sea utilizada. Al parámetro de la clase genérica se le proporciona un nombre (T, K, J, etc.) que permite utilizarlo como tipo de datos en el código de la clase. Sobre las variables cuyo tipo sea el parámetro (T, K, J, etc.) sólo es posible aplicar métodos de la clase Object: dado que representan cualquier dato sólo podemos aplicar operaciones disponibles en todos los tipos de datos del lenguaje Java. Curso 2015/2016 Programación Orientada a Objetos 4

Clase genérica Contenedor public class Contenedor<T> { private T contenido; public void setcontenido(t contenido) { this.contenido = contenido; public T getcontenido() { return contenido; Curso 2015/2016 Programación Orientada a Objetos 5

Operaciones disponibles Las operaciones aplicables sobre cualquier objeto (métodos públicos de la clase Object) Podemos aplicar la asignación (=) y la comparación de identidad (== o!=). Dentro de la clase genérica, NO es posible construir objetos de los tipos parametrizados: T contenido = new T(); // No compila Curso 2015/2016 Programación Orientada a Objetos 6

Uso de una clase genérica La parametrización de una clase genérica se realiza en la declaración de una variable y en la construcción de objetos. Contenedor<String> contenedor = new Contenedor<String>(); contenedor.setcontenido("hola"); Curso 2015/2016 Programación Orientada a Objetos 7

Genericidad y tipos primitivos Las clases genéricas no pueden ser parametrizadas a tipos primitivos. Para resolver este problema el lenguaje define clases envoltorio de los tipos primitivos: Integer, Float, Double, Character, Boolean, etc. El compilador transforma automáticamente tipos primitivos en clases envoltorio y viceversa: autoboxing. Contenedor<Integer> contenedor = new Contenedor<Integer>(); contenedor.setcontenido(10); int valor = contenedor.getcontenido(); Curso 2015/2016 Programación Orientada a Objetos 8

Genericidad restringida Objetivo: limitar los tipos a los que puede ser parametrizada una clase genérica. Al restringir los tipos obtenemos el beneficio de poder aplicar métodos sobre los objetos del tipo parametrizado. Una clase con genericidad restringida sólo permite ser parametrizada con tipos compatibles con el de la restricción (clase o interfaz). Curso 2015/2016 Programación Orientada a Objetos 9

Genericidad restringida Ejemplo: la clase CarteraAhorro sólo puede ser parametrizada con tipos compatibles con Deposito. Podemos aplicar métodos disponibles en la clase Deposito. public class CarteraAhorro<T extends Deposito> { private LinkedList<T> contenido; public void liquidar() { for (T deposito : contenido) deposito.liquidar(); Curso 2015/2016 Programación Orientada a Objetos 10

Genericidad restringida Una clase genérica puede estar restringida por varios tipos: public class Contenedor<T extends Deposito & Amortizable> Las operaciones disponibles para objetos de tipo T es la unión de todos los tipos de la restricción. En el ejemplo, todas las operaciones de la clase Deposito y la interfaz Amortizable. Curso 2015/2016 Programación Orientada a Objetos 11

Genericidad y sistema de tipos Deposito Contenedor<Deposito> No hay relación DepositoEstructurado Contenedor<DepositoEstructurado> Contenedor<Deposito> cdeposito; Contenedor<DepositoEstructurado> cestructurado; cdeposito = cestructurado; // No compila Curso 2015/2016 Programación Orientada a Objetos 12

Genericidad y sistema de tipos Las reglas del polimorfismo se mantienen entre clases genéricas. Sin embargo, en una asignación polimórfica no está permitido que tengan distintos parámetros. En el ejemplo, las dos variables son del mismo tipo (Contenedor), pero han sido parametrizadas a tipos distintos (Deposito y DepositoEstructurado). No importa que Deposito y DepositoEstructurado sean tipos compatibles. Es una limitación en el paso de parámetros. Curso 2015/2016 Programación Orientada a Objetos 13

Genericidad y sistema de tipos Problema: el método sólo permite objetos de tipo List<Deposito>. public double posicionglobal(list<deposito> depositos) { double posicion = 0; for (Deposito deposito : depositos) { posicion += deposito.getcapital(); return posicion; Cómo podemos pasar una variable de tipo List<DepositoEstructurado>? Curso 2015/2016 Programación Orientada a Objetos 14

Genericidad y sistema de tipos Solución: tipo comodín. public double posicionglobal( List<? extends Deposito> depositos) En el ejemplo significa: permite cualquier lista genérica parametrizada a la clase Depósito o a un tipo compatible (subclase). El tipo comodín se puede usar también para declarar variables locales o atributos. No se puede utilizar para construir objetos. Si se indica simplemente <?>, significa cualquier tipo. Curso 2015/2016 Programación Orientada a Objetos 15

Genericidad Características avanzadas Dentro de una clase genérica se pueden utilizar otras clases genéricas. Una clase genérica puede tener varios parámetros. Una interfaz también puede declarar parámetros: Un ejemplo son las interfaces que definen las colecciones. public class ContenedorDoble <T,K> { private String nombre; private Contenedor<T> clave; private K valor; ContenedorDoble<String, Cuenta> contenedor = Curso 2015/2016 Programación Orientada a Objetos 16

Genericidad Características avanzadas Es posible utilizar una clase genérica y no establecer sus parámetros (tipo puro). En tiempo de ejecución no se puede consultar el parámetro al que fue instanciada una clase genérica. Se puede aplicar herencia con clases genéricas. Curso 2015/2016 Programación Orientada a Objetos 17

Genericidad Tipo puro Cuando se declara una variable cuyo tipo se corresponde con una clase genérica y no se especifica el parámetro se asigna el tipo puro (raw) que corresponde a: Sin genericidad restringida, la clase Object. Con genericidad restringida, la clase a la que se restringe. Contenedor contenedor = new Contenedor(); // Object CarteraAhorro cartera = new CarteraAhorro(); // Deposito Siendo: Clase Contenedor<T> Clase CarteraAhorro<T extends Deposito> Curso 2015/2016 Programación Orientada a Objetos 18

Genericidad Tiempo de ejecución En tiempo de ejecución se pierde la información sobre el tipo utilizado para parametrizar la clase genérica. Todo tipo genérico (clase genérica parametrizada) se transforma a un tipo puro. Con el operador instanceof sólo podemos preguntar por el nombre de la clase. // No compila if (contenedor instanceof Contenedor<Deposito>) { // Sí compila if (contenedor instanceof Contenedor) { Curso 2015/2016 Programación Orientada a Objetos 19

Genericidad y herencia Una clase puede heredar de una clase genérica. La nueva clase tiene las opciones: Mantener la genericidad de la clase padre. public class CajaSeguridad<T> extends Contenedor<T> Restringir la genericidad. public class CajaSeguridad<T extends Valorable> extends Contenedor<T> No ser genérica y especificar un tipo concreto. public class CajaSeguridad extends Contenedor<Valorable> Curso 2015/2016 Programación Orientada a Objetos 20

Ejemplo herencia public class Par<T, P> { private T valor1; private P valor2; public Par(T valor1, P valor2) { this.valor1 = valor1; this.valor2 = valor2; public T getvalor1() { return valor1; public P getvalor2() { return valor2; public void setvalor1(t valor1) { this.valor1 = valor1; public void setvalor2(p valor2) { this.valor2 = valor2; Curso 2015/2016 Programación Orientada a Objetos 21

Ejemplo herencia public class ParUniforme<T> extends Par<T, T> { public ParUniforme(T valor1, T valor2) { super(valor1, valor2); public boolean contiene(t valor) { return getvalor1().equals(valor) getvalor2().equals(valor); Curso 2015/2016 Programación Orientada a Objetos 22

Ejemplo herencia public class ParNumerico<T extends Number> extends ParUniforme<T> { public ParNumerico(T valor1, T valor2) { super(valor1, valor2); public double suma() { double valor1 = getvalor1().doublevalue(); double valor2 = getvalor2().doublevalue(); return valor1 + valor2; Curso 2015/2016 Programación Orientada a Objetos 23

Ejemplo herencia public class Programa { public static void main(string[] args) { ParNumerico<Double> par = new ParNumerico<Double>(3.2, 5.1); ParNumerico<Integer> par2 = new ParNumerico<Integer>(3, 5); ParUniforme<Integer> uniforme = par2; System.out.println(uniforme.contiene(7)); System.out.println(par.suma()); Curso 2015/2016 Programación Orientada a Objetos 24

Métodos genéricos Un método que declara una variable de tipo se denomina método genérico. Antes de la declaración del tipo de retorno del método se indica una variable que representa el tipo (<T>). El alcance de la variable de tipo (<T>) es local al método, esto es, puede aparecer en la signatura del método y en el cuerpo del método. Es posible definir métodos genéricos incluso en clases que no son genéricas. Curso 2015/2016 Programación Orientada a Objetos 25

Ejemplo 1 Método que acepta una secuencia de valores de cualquier tipo y lo convierte en una lista: public static <T> List<T> aslist (T... datos) { List<T> lista = new ArrayList<T>(datos.length); for (T elemento : datos) lista.add(elemento); return lista; Curso 2015/2016 Programación Orientada a Objetos 26

Ejemplo 1 El método aslist se podría invocar como sigue: public static void main(string[] args) { List<Integer> listaenteros = aslist(1,2,3); String[] arraypalabras = {"hola", "ciao", "hello"; List<String> listapalabras = aslist(arraypalabras); El valor de T se infiere a partir del tipo de los argumentos. Curso 2015/2016 Programación Orientada a Objetos 27

Ejemplo 2 Añade una secuencia variable de elementos a una lista: public static <T> void addall (List<T> lista, T... elementos) { for (T elemento : elementos) lista.add(elemento); List<Integer> enteros = new ArrayList<Integer>(); addall(enteros, 1, 2, 3); Curso 2015/2016 Programación Orientada a Objetos 28

Ejemplo 3 public static <T> T getelementoaleatorio(list<t> lista){ Random random = new Random(); int index = random.nextint(lista.size()); return lista.get(index); List<Integer> enteros = new ArrayList<Integer>(); addall(enteros, 1, 2, 3); int entero = getelementoaleatorio(enteros); Curso 2015/2016 Programación Orientada a Objetos 29

Seminario 3 El Seminario 3 trata la genericidad en Java e incluye los siguientes ejemplos: Genericidad basada en Object. Definición de una clase genérica. Genericidad restringida. Curso 2015/2016 Programación Orientada a Objetos 30

Contenido Parte II Colecciones (paquete java.util): Interfaz Collection<T> Interfaz List<T> Interfaz Set<T> Interfaz Map<K,T> Copia colecciones. Orden objetos. Iteradores. Recomendaciones. Curso 2015/2016 Programación Orientada a Objetos 31

Colecciones en Java Las colecciones en Java son un ejemplo destacado de implementación de código reutilizable utilizando un lenguaje orientado a objetos. Todas las colecciones son genéricas. Los tipos abstractos de datos se definen como interfaces. Se implementan clases abstractas que permiten factorizar el comportamiento común a varias implementaciones. Un mismo TAD puede ser implementado por varias clases List: LinkedList, ArrayList Curso 2015/2016 Programación Orientada a Objetos 32

Colecciones en Java Iterator devuelve Collection devuelve Map devuelve ListIterator List Set SortedMap AbstractMap AbstractCollection SortedSet TreeMap HashMap AbstractList AbstractSet HashSet TreeSet ArrayList AbstractSequentialList LinkedList extends implements interface class Curso 2015/2016 Programación Orientada a Objetos 33

Interfaz Collection<T> Define las operaciones comunes a todas las colecciones de Java. Permite usar colecciones basándonos en su interfaz en lugar de en la implementación. Los tipos básicos de colecciones son (subtipos de Collection<T>) : Listas, definidas en la interfaz List<T> Conjuntos, definidos en la interfaz Set<T> Curso 2015/2016 Programación Orientada a Objetos 34

Interfaz Collection<T> Operaciones básicas de consulta: size(): devuelve el número de elementos. isempty(): indica si tiene elementos. contains(object e): indica si contiene el objeto pasado como parámetro utilizando el método equals. Curso 2015/2016 Programación Orientada a Objetos 35

Interfaz Collection<T> Operaciones básicas de modificación: add(t e): añade un elemento a la colección. Retorna un booleano indicando si acepta la inserción. remove(object e): intenta eliminar el elemento. Retorna un booleano indicando si ha sido eliminado. Utiliza el método equals para localizar el objeto. clear(): elimina todos los elementos. addall(collection<? extends T> col): añade todos los elementos de la colección col removeall(collection<?> col): elimina todos los objetos contenidos en col Curso 2015/2016 Programación Orientada a Objetos 36

Interfaz List<T> La interfaz List<T> define secuencias de elementos a los que se puede acceder atendiendo a su posición. Las posiciones van de 0 a size()-1. El acceso a una posición ilegal produce la excepción IndexOutOfBoundsException El método add(t e) añade al final de la lista. Añade a las operaciones de Collection métodos de acceso por posición como: T get (int index) T set (int index, T element) void add (int index, T element) T remove (int index) Curso 2015/2016 Programación Orientada a Objetos 37

Clases que implementan List<T> ArrayList<T> Implementación basada en arrays redimiensionables. Operaciones de inserción y modificación ineficientes. Operaciones de creación y consulta rápidas. LinkedList<T> Implementación basada en listas doblemente enlazadas Inserciones y modificaciones rápidas, especialmente en el principio y el final: Métodos no disponibles en List<T>: addfirst, addlast, removefirst, removelast Acceso aleatorio a elementos ineficiente. Acceso eficiente al principio y al final de la lista: getfirst y getlast Curso 2015/2016 Programación Orientada a Objetos 38

Interfaz Set<T> La interfaz Set<T> define conjuntos de elementos no repetidos. Implementaciones de conjuntos: HashSet<T>: Guarda los elementos del conjunto en una tabla hash. Para evitar la inserción de elementos repetidos, la igualdad de los objetos se comprueba comparando los hashcode, si son iguales se compara con equals. TreeSet<T>: Implementación de conjuntos ordenados basada en árboles binarios balanceados. Para su funcionamiento es necesario definir un orden (se estudia más adelante). Las operaciones de búsqueda y modificación son más lentas en TreeSet que en HashSet Curso 2015/2016 Programación Orientada a Objetos 39

Interfaz Map<K,V> La interfaz Map<K,V> define el tipo de datos que representa pares <clave, valor> Un mapa no puede tener claves duplicadas. Cada clave sólo puede tener un valor asociado. Un mapa no es una colección, sin embargo contiene distintas colecciones: Conjunto de claves (Set<K>) Colección de valores (Collection<V>) Conjunto de pares <clave, valor> (Map.Entry<K,V>) Las implementaciones disponibles son: HashMap<T>: implementación basada en una tabla hash TreeMap<T>: implementación basada en árboles balanceados. Las claves están ordenadas (SortedSet<K>). Curso 2015/2016 Programación Orientada a Objetos 40

Interfaz Map<K,V> Métodos básicos: V put(k clave, V valor): inserta una asociación en el mapa. Retorna el valor de la antigua asociación, si la hubiera. V get(clave): retorna el valor asociado a una clave. Si la asociación no existe, devuelve nulo. Set<K> keyset(): devuelve el conjunto de claves. Collection<V> values(): devuelve la colección de valores. boolean containskey(key): indica si existe una clave. Set<Map.Entry<K, V>> entryset(): devuelve el conjunto de todas las asociaciones, Map.Entry<K, V>: getkey(): consultar la clave. getvalue(): consultar el valor. Curso 2015/2016 Programación Orientada a Objetos 41

Copia de colecciones Todas las clases que implementan colecciones ofrecen un constructor de copia y el método clone. En ambos casos construye una copia superficial del objeto receptor. puntos LinkedList<Punto> puntos; LinkedList<Punto> copia; // Opción 1: copia con clone copia = (LinkedList<Punto>)puntos.clone(); 0 0 2 0 0 2 2 2 // Opción 2: constructor de copia copia = new LinkedList<Punto>(puntos); copia Curso 2015/2016 Programación Orientada a Objetos 42

Orden de los objetos El orden utilizado por las colecciones ordenadas (SortedSet, SortedMap) puede ser el orden natural de los objetos (por defecto) o el criterio de ordenación que se establece en el constructor. La interfaz Comparable impone el orden natural de los objetos de las clases que la implementan. public interface Comparable<T> { public int compareto(t o); El método compareto devuelve un entero positivo si la relación es mayor que, negativo si es menor que y cero si son iguales. Curso 2015/2016 Programación Orientada a Objetos 43

Orden natural de Cuenta public class Cuenta implements Comparable<Cuenta>{ public int compareto(cuenta otracta) { if (this.codigo > otracta.codigo) return 1; else if (this.codigo < otracta.codigo) return -1; else return 0; Curso 2015/2016 Programación Orientada a Objetos 44

TreeSet<Cuenta> con orden natural public class Persona { private TreeSet<Cuenta> miscuentas; public Persona(String dni, String nombre){ //TreeSet utiliza el orden natural de la clase Cuenta miscuentas = new TreeSet<Cuenta>(); /** * Añade una cuenta a la colección de la persona que es titular * @param cta Cuenta a añadir en la colección * @return true si la cuenta se ha añadido y false en caso contrario */ public boolean addcuenta(cuenta cta){ return miscuentas.add(cta); Curso 2015/2016 Programación Orientada a Objetos 45

Criterios de ordenación Para definir un criterio de ordenación hay que implementar la interfaz Comparator. public interface Comparator<T> { public int compare(t o1, T o2); El método compare devuelve un entero positivo si la relación es mayor que, negativo si es menor que y cero si son iguales. Se utiliza un criterio de ordenación cuando los objetos que queremos ordenar no tienen orden natural o ese orden no interesa usarlo. Curso 2015/2016 Programación Orientada a Objetos 46

Criterios de ordenación para Cuenta public class OrdenSaldo implements Comparator<Cuenta>{ public int compare(cuenta o1, Cuenta o2) { if (o1.getsaldo() > o2.getsaldo()) return 1; else if (o1.getsaldo() < o2.getsaldo()) return -1; else return 0; Curso 2015/2016 Programación Orientada a Objetos 47

Criterios de ordenación para Cuenta public class OrdenTitular implements Comparator<Cuenta> { public int compare(cuenta o1, Cuenta o2) { return (o1.gettitular().getnombre(). compareto(o1.gettitular().getnombre())); Curso 2015/2016 Programación Orientada a Objetos 48

TreeSet<Cuenta> con criterio de ordenación public class Persona { private TreeSet<Cuenta> miscuentas; public Persona(String dni, String nombre){ miscuentas = new TreeSet<Cuenta>(new OrdenTitular()); //TreeSet utiliza el orden establecido //en la clase OrdenTitular para ordenar las cuentas Curso 2015/2016 Programación Orientada a Objetos 49

Iteradores Las colecciones de Java son iterables, es decir, podemos recorrer todos sus elementos. Se utilizan iteradores para que el código que realiza el recorrido no conozca las particularidades de la estructura de datos: lista enlazada, lista basada en arrays, etc. public double posicionglobal(list<deposito> depositos) { double posicion = 0; for (Deposito deposito : depositos) { posicion += deposito.getcapital(); return posicion; Curso 2015/2016 Programación Orientada a Objetos 50

Iteradores Java proporciona la interfaz Iterable<T> que debe ser implementada por aquellas clases sobre las que se pueda iterar: public interface Iterable<T> { Iterator<T> iterator(); A los objetos iterables se les exige que creen objetos iterador (Iterator) para realizar la iteración. Los arrays y la interfaz Collection son iterables. Curso 2015/2016 Programación Orientada a Objetos 51

Iteradores Interfaz Iterator<T>: hasnext(): indica si quedan elementos en la iteración. next(): devuelve el siguiente elemento de la iteración. remove(): elimina el último elemento devuelto por el iterador. public interface Iterator<T> { boolean hasnext(); T next(); void remove(); Curso 2015/2016 Programación Orientada a Objetos 52

Recorrido for each El recorrido for each permite recorrer objetos iterables sin manejar un objeto iterador. Es la opción más común de recorrido. public double posicionglobal(list<deposito> depositos) { double posicion = 0; for (Deposito deposito : depositos) { posicion += deposito.getcapital(); return posicion; Curso 2015/2016 Programación Orientada a Objetos 53

Recorrido explícito con iterador Interesa manejar un iterador cuando queremos eliminar algún elemento de la colección. En Java sólo se puede modificar una colección que se está recorriendo utilizando explícitamente el iterador. public double filtrar(list<deposito> depositos) { Iterator<Deposito> it = depositos.iterator(); while (it.hasnext()) { Deposito deposito = it.next(); if (deposito.getcapital() < 1000) it.remove(); Curso 2015/2016 Programación Orientada a Objetos 54

Recomendaciones Programar hacia el TAD En constructores y métodos públicos, el tipo de retorno y el tipo de los parámetros se especifica utilizando la interfaz (por ejemplo List en lugar de LinkedList) Las colecciones tienen más funcionalidad que los arrays. Podemos obtener una lista a partir de un array: List<Deposito> lista = Arrays.asList(depositos); Curso 2015/2016 Programación Orientada a Objetos 55

Recomendaciones Los colecciones suelen producir aliasing incorrectos. Soluciones: Copiar la colección (clone o constructor de copia). Devolver una vista no modificable de la colección: Collections.unmodifiableList(depositos); Existe una operación análoga para cada interfaz de las colecciones. Es recomendable documentar que se devuelve una vista no modificable. Es más eficiente que construir una copia. Curso 2015/2016 Programación Orientada a Objetos 56