Wprowadzenie do języka Java Kolekcje w języku Java Bartosz Walter.

1 Wprowadzenie do języka Java Kolekcje w języku Java Bart...
Author: Marek Jabłoński
0 downloads 0 Views

1 Wprowadzenie do języka Java Kolekcje w języku Java Bartosz Walter

2 Szkolenie z języka Java Biblioteka Java Collections (2) Plan wykładu Historia Java Collections Podstawowe interfejsy i ich odpowiedzialność Iteratory Klasy pomocnicze i ich funkcjonalność Obiekty opakowujące Porównywanie obiektów Typy generyczne

3 Szkolenie z języka Java Biblioteka Java Collections (3) Historia 1995: JDK 1.0 –niezależne klasy kolekcji: tablice Vector, Hashtable o niespójnym sposobie dostępu do elementów –brak wydzielonych interfejsów 1998: JDK 1.2 –oparcie kolekcji na interfejsach Collection, Set, List i Map oraz różnorodnych implementacjach –iteratory, algorytmy, porównania 2005: JDK 1.5 –wprowadzenie typów generycznych

4 Szkolenie z języka Java Biblioteka Java Collections (4) Interfejs java.util.Collection

5 Szkolenie z języka Java Biblioteka Java Collections (5) Collection: specyfikacja Wspólny interfejs dla większości kolekcji Reprezentuje obiekt zarządzający grupą elementów Brak ograniczeń dotyczących elementów Dwa obligatoryjne konstruktory: –bezparametrowy: Collection() –kopiujący: Collection(Collection src) Konstruktor zapewnia utworzenie obiektu zgodnego z semantyką danej kolekcji Metody nieobowiązkowe mogą zgłaszać wyjątek java.lang.UnsupportedOperationException Brak bezpośredniej implementacji w JDK

6 Szkolenie z języka Java Biblioteka Java Collections (6) Collection: przegląd wybranych metod operacje podstawowe – wykonywane na obiektach boolean add(Object obj) boolean remove(Object obj) boolean contains(Object obj) operacje grupowe – wykonywane na kolekcjach obiektów boolean addAll(Collection coll) boolean removeAll(Collection coll) boolean containsAll(Collection coll) boolean retainAll(Collection coll) void clear()

7 Szkolenie z języka Java Biblioteka Java Collections (7) Collection: przegląd wybranych metod cd. inspekcja int size() boolean isEmpty(Object obj) iteracja Iterator iterator() operacje na tablicach – konwersja do tablic Object[] toArray() Object[] toArray(Object[] type)

8 Szkolenie z języka Java Biblioteka Java Collections (8) Interfejs java.util.List

9 Szkolenie z języka Java Biblioteka Java Collections (9) List: specyfikacja Reprezentacja uporządkowanej sekwencji elementów Większość implementacji dopuszcza istnienie duplikatów elementów Najważniejsze implementacje: ArrayList, LinkedList, Vector, Stack AlamakotaakotmaAlę 0 1 6 2 długość: 7 wycinek 4-6

10 Szkolenie z języka Java Biblioteka Java Collections (10) List: przegląd wybranych metod dostęp pozycyjny do elementów Object get(int indeks) Object set(int indeks) Object add(int indeks) Object remove(int indeks) wyszukiwanie int indexOf(Object obiekt) int lastIndexOf(Object obiekt) rozszerzona iteracja ListIterator listIterator() widok przedziałowy List subList(int poczatek, int koniec)

11 Szkolenie z języka Java Biblioteka Java Collections (11) Interfejs java.util.Queue

12 Szkolenie z języka Java Biblioteka Java Collections (12) Queue: specyfikacja Bezpośredni potomek interfejsu Collection Reprezentacja kolejki (LIFO, FIFO, priorytetowa) Podział na pierwszy element (głowę) i pozostałą część kolejki (ogon) Najważniejsze implementacje: LinkedList, PriorityQueue głowa ogon AlamakotaakotmaAlę

13 Szkolenie z języka Java Biblioteka Java Collections (13) Queue: przegląd metod Metody niezależne od interfejsu Collection: dodawanie elementu boolean offer(Object obiekt) usuwanie elementu Object remove() Object poll() inspekcja Object element() Object peek()

14 Szkolenie z języka Java Biblioteka Java Collections (14) Przykład public class Odliczanie { public static void main(String[] args) { int liczba = Integer.parseInt(args[0]); Queue kolejka = new LinkedList(); for (int i = liczba; i >= 0; i--) { kolejka.add(i); } while (!kolejka.isEmpty()) { System.out.println(kolejka.remove()); }

15 Szkolenie z języka Java Biblioteka Java Collections (15) Interfejs java.util.Set

16 Szkolenie z języka Java Biblioteka Java Collections (16) Set: specyfikacja Reprezentacja zbioru matematycznego –brak relacji porządku wewnątrz zbioru –brak duplikatów Brak nowych metod w stosunku do Collection najważniejsze implementacje: HashSet, TreeSet Ala ma kota a kot Alę

17 Szkolenie z języka Java Biblioteka Java Collections (17) Przykład public class Duplikaty { public static void main(String args[]) { Set s = new HashSet(); for (int i = 0; i < args.length; i++) { if (! s.add(args[i])) System.out.println("Duplikat!"); }

18 Szkolenie z języka Java Biblioteka Java Collections (18) Interfejs java.util.Map

19 Szkolenie z języka Java Biblioteka Java Collections (19) Map: specyfikacja Kolekcja jednoznacznych odwzorowań klucz-wartość Klucze, wartości i pary klucz-wartość dostępne jako obiekty Collection Dwa obowiązkowe konstruktory (analogicznie do kolekcji) Najważniejsze implementacje: HashMap, TreeMap, SortedMap "Ala" "kot" "kota" "Alę" kluczewartości "Ola"

20 Szkolenie z języka Java Biblioteka Java Collections (20) Map: przegląd metod operacje podstawowe Object put(Object klucz, Object wartosc) Object get(Object klucz) Object remove(Object klucz) boolean containsKey(Object klucz) boolean containsValue(Object wartosc) operacje grupowe void putAll(Map zrodlo) widoki-kolekcje Set keySet() Collection values() Set entrySet()

21 Szkolenie z języka Java Biblioteka Java Collections (21) Przykład public class Czestotliwosc { private static final Integer JEDEN = new Integer(1); public static void main(String args[]) { Map mapa = new HashMap(); for (int i=0; i

22 Szkolenie z języka Java Biblioteka Java Collections (22) Iteratory

23 Szkolenie z języka Java Biblioteka Java Collections (23) Iteratory: specyfikacja Umożliwiają sekwencyjny dostęp do wszystkich elementów kolekcji niezależnie od jej implementacji Dwa rodzaje iteratorów –java.util.Iterator – istnieje w każdej kolekcji –java.util.ListIterator – istnieje tylko w listach, wykorzystuje jej rozszerzone możliwości Ala ma kota a kot Alę Iterator bieżący element: "Ala" następny elenent: "kot" kolekcja

24 Szkolenie z języka Java Biblioteka Java Collections (24) Przykład public class Iteracja { public static void main(String args[]) { Collection coll = new ArrayList(); for (int i = 0; i < args.length; i++) { coll.add(args[i]); } for (Iterator iter = coll.iterator(); iter.hasNext();) String element = (String) iter.next(); System.out.println("element = " + element); } > java Iteracja Ala ma kota element = Ala element = ma element = kota

25 Szkolenie z języka Java Biblioteka Java Collections (25) Klasy pomocnicze

26 Szkolenie z języka Java Biblioteka Java Collections (26) Algorytmy Metody statyczne klasy Collections implementują typowe algorytmy wykonywane na kolekcjach: wyszukiwanie binarne sortowanie operacje algebraiczne na zbiorach odwracanie list permutacje list wyszukiwanie elementów max/min

27 Szkolenie z języka Java Biblioteka Java Collections (27) Niezmienność kolekcji Klasa Collections posiada także metody statyczne, pozwalające zmieniać własności kolekcji, np. blokować metody modyfikujące kolekcję –Collection immutableCollection(Collection kol) –List immutableList(List lista) –Set immutableSet(Set zbior) –Map immutableMap(Map mapa) Metody te w rzeczywistości tworzą obiekt opakowujący kolekcję i przechwytujący wywołania metod

28 Szkolenie z języka Java Biblioteka Java Collections (28) Przykład kolekcja dekorator kolekcji add()size() Kolekcja Collection jest "opakowana" w obiekt blokujący niektóre metody. Wywołania metody size() są przez obiekt opakowujący delegowane do wewnętrznej kolekcji, natomiast metody add() – blokowane.

29 Szkolenie z języka Java Biblioteka Java Collections (29) Inne klasy opakowujące Analogicznie, w klasie Collections istnieją inne metody tworzące specjalizowane obiekty opakowujące; nazwy metod są zgodne z konwencją i zależą od interfejsu –Interfejs synchronizedInterfejs(Interfejs i) zapewnia synchronizację dostępu do interfejsu; wielowątkowy dostęp powoduje zgłoszenie wyjątku –Interfejs checkedInterfejs(Interfejs i) zapewnia weryfikację typu wstawianego elementu do kolekcji

30 Szkolenie z języka Java Biblioteka Java Collections (30) Porównywanie obiektów

31 Szkolenie z języka Java Biblioteka Java Collections (31) Porównywanie obiektów Wiele algorytmów wykonywanych na kolekcjach (np. sortowanie, wyszukiwanie) wymaga zdefiniowania relacji częściowego porządku Relacja porównania jest intuicyjnie zdefiniowana dla liczb, ale nie dla obiektów –Czy można porównać obiekty różnych klas? –Jak porównać dwie osoby? Porównywalność jest własnością obiektu, którą można z niego wyłączyć Java Collections korzysta z dwóch interfejsów służących do porównywania obiektów –java.lang.Comparable –java.util.Comparator

32 Szkolenie z języka Java Biblioteka Java Collections (32) Interfejs Comparable Jak posortować listę osób wg daty urodzenia? –Collections.sort(people) public class Person implements Comparable { private Date birthday; public Date getBirthday() { return birthday; } public int compareTo (Object obj) { String birthday = ((Person) obj).getBirthday(); return (this.birthday.compareTo(birthday)); }

33 Szkolenie z języka Java Biblioteka Java Collections (33) Interfejs Comparable cd. Jak posortować listę osób wg daty urodzenia? –Collections.sort(people) Sortowanie jest możliwe tylko dla list zawierających obiekty implementujące interfejs java.lang.Comparable Comparable definiuje jedną metodę, compareTo(Object o), która zwraca –mniej niż 0 – gdy jej parametr jest większy niż własny obiekt –0 – gdy jej parametr jest równy własnemu obiektowi –więcej niż 0 – gdy jej parametr jest mniejszy niż własny obiekt

34 Szkolenie z języka Java Biblioteka Java Collections (34) Interfejs Comparator Interfejs Comparator oferuje podobną funkcjonalność jak Comparable, ale porównuje ze sobą dwa obiekty przekazane jako parametry Comparator definiuje jedną metodę, compare (Object o1, Object o2), analogiczną do metody Comparable.compareTo(Object o) Comparator przekazywany jest jako parametr metod sortujących, wyszukujących etc. –Collections.sort(people, comparator) Sortowanie z wykorzystaniem interfejsu Comparator jest możliwe dla dowolnych obiektów

35 Szkolenie z języka Java Biblioteka Java Collections (35) Przykład public class BirthdayComparator implements Comparator{ public int compare (Object obj1, Object obj2) { Date birthday1 = ((Person) obj1).getBirthday(); Date birthday2 = ((Person) obj1).getBirthday(); return birthday1.compareTo(birthday2); } Collections.sort(people, new BirthdayComparator());

36 Szkolenie z języka Java Biblioteka Java Collections (36) Typy generyczne Wprowadzone w Java 5.0 SE (a.k.a. JDK 1.5) Przykład polimorfizmu parametrycznego: typ obiektu zależy od parametru weryfikowanego w momencie uruchomienia, a nie kompilacji Weryfikacja typów obiektów w momencie kompilacji, potem typy są wymazywane (ang. erasure) List lista = new ArrayList ();

37 Szkolenie z języka Java Biblioteka Java Collections (37) Przykład List coll = new ArrayList(); for (Iterator iter = coll.iterator(); iter.hasNext(); ) Person osoba = (Person) iter.next(); System.out.println("osoba = " + person); } List coll = new ArrayList (); for (Iterator iter = coll.iterator(); iter.hasNext(); ) Person osoba = iter.next(); System.out.println("osoba = " + person); } Tradycyjne odwołania do kolekcji Wykorzystanie typów generycznych

38 Szkolenie z języka Java Biblioteka Java Collections (38) Podsumowanie Java Collections przykładem biblioteki ewoluującej wraz z rozwojem języka Przykład dobrego wykorzystania interfejsów i implementacji Przemyślany podział odpowiedzialności interfejsów Rola wzorców projektowych Wykorzystanie najnowszych zmian w języku`