INF1010, 21. februar Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

Like dokumenter
1. Krav til klasseparametre 2. Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

INF1010, 23. februar Parametriserte klasser Om å gå gjennom egne beholdere (subklasser og grensesnitt 3)

INF1010, 15. januar time. Parametriserte klasser (generiske klasser) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

INF1010, 21. januar Klasser med parametre = Parametriserte klasser = Generiske klasser

INF1010. Grensesnittet Comparable<T>

Algoritmer og datastrukturer Kapittel 3 - Delkapittel 3.1

INF1010. grensesni-et Comparable<T> grensesni-et Iterable<T> rekursjon

Lenkelister, iteratorer, indre klasser. Repetisjonskurs våren 2018 kristijb

PG4200 Algoritmer og datastrukturer Forelesning 5 Implementasjon av lister

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5)

IN1010 våren januar. Objektorientering i Java

Enkle generiske klasser i Java

INF1010 våren Grensesnitt

INF1010 våren Grensesnitt

Gjennomgang av eksamen H99

INF1010 våren januar. Objektorientering i Java

Løsningsforslag til eksamen i INF1000 våren 2006

< T extends Comparable<T> > Indre klasser mm. «Det du bør ha hørt om før oblig 4»

UNIVERSITETET I OSLO

INF Notater. Veronika Heimsbakk 10. juni 2012

(MVC - Model, View, Control)

INF1010, 22. mai Prøveeksamen (Eksamen 12. juni 2012) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

Hva er verdien til variabelen j etter at følgende kode er utført? int i, j; i = 5; j = 10; while ( i < j ) { i = i + 2; j = j - 1; }

INF1010 våren 2019 Onsdag 30. januar. Mer om unntak i Java (med litt repetisjon av I/O først)

INF Løsning på seminaropppgaver til uke 8

Innhold. INF1000 Høst Unified Modeling Language (UML) Unified Modeling Language (UML)

INF1010 våren Grensesnitt (interface)

INF1010 våren 2018 tirsdag 23. januar

Abstrakte metoder og klasser. Abstrakte metoder og klasser. Uke 9 INF1010, 27. februar 2007, Abstrakte klasser og grensesnitt (interface)

PG4200 Algoritmer og datastrukturer Forelesning 7

UNIVERSITETET I OSLO

INF våren 2017

Løsningsforslag Test 2

Eks 1: Binærtre Binærtretraversering Eks 2: Binærtre og stakk

IN våren 2018 Tirsdag 16. januar

IN våren 2019 Onsdag 16. januar

Dagens forelesning. Husk prøveeksamen Fredag 15/3-13 kl 12 i R1. Iterator-teknikken. Eksempel med bruk av Iterator og Iterable-grensesnittene

HashMap. INF1000 Forelesning 9. Ulike versjoner i Java 1.4 (gammel) og Java 1.5/1.6 av HashMap. Objekter lagres med en søkenøkkel

INF1000 Forelesning 9. Hashmap Eksempel: Flyreservasjon

INF1010 våren 2017 Onsdag 25. januar. Litt om unntak i Java

Algoritmer og datastrukturer Eksamen

INF1010 våren februar. Arv og subklasser, del 2

OPPGAVE 5b og 8b Java Kode

INF Våren Li' repe$sjon om Tråder og GUI. Stein Gjessing, Ins$tu' for informa$kk, Universitetet i Oslo. Ins$tu' for informa$kk

Forkurs INF1010. Dag 3. Andreas Færøvig Olsen Eivind Storm Aarnæs

2 Om statiske variable/konstanter og statiske metoder.

Eksamen INF1010 V2009 Del B prøveeksamen V2010 Vekt 60 %

Gjøre noe i hele treet = kalle på samme metode i alle objekten. Java datastruktur Klassestruktur

Forkurs INF1010. Dag 3. Andreas Færøvig Olsen Gard Inge Rosvold Institutt for Informatikk, 15.

Algoritmer og datastrukturer Løsningsforslag

UNIVERSITETET I OSLO

IN1010 våren 2018 Tirsdag 15. mai. Repetisjon av subklasser og tråder. Stein Gjessing Institutt for informatikk Universitetet i Oslo

Uke 6 INF1010, 5. februar 2008, Abstrakte klasser og grensesnitt (interface) Stein Gjessing Inst for Informatikk Univ. i Oslo

Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister

Oppgave 1. Oppgave 2. Oppgave 3. Prøveeksamen i INF1000. Ole Christian og Arne. 23. november 2004

INF1010 våren februar. Arv og subklasser, del 2. Repetisjon. Repetisjon - Biler. Repetisjon: Klasser - Subklasser

Prøveeksamen i INF1000. Ole Christian og Arne. 23. november 2004

Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister Videre

INF Seminaroppgaver til uke 3

Oppgave 1. INF1000 Uke 13. Oppgave 2. Oppgave 3. Er dette lovlige deklarasjoner (når de foretas inni en metode)? JA NEI

INF1000 (Uke 15) Eksamen V 04

INF1000 (Uke 15) Eksamen V 04

INF1010 våren Interface (Grensesnitt)

Oppsummering. Kort gjennomgang av klasser etc ved å løse halvparten av eksamen Klasser. Datastrukturer. Interface Subklasser Klasseparametre

UNIVERSITETET I OSLO

Dagens forelesning. Java 13. Rollefordeling (variant 1) Rollefordeling (variant 2) Design av større programmer : fordeling av roller.

UNIVERSITETET I OSLO

Hva er en liste? Hvert element har en forgjenger, unntatt første element i listen. Hvert element har en etterfølger, unntatt siste element i listen

INF1010. Stein Michael Storleer (michael) Lenkelister

Velkommen til. INF våren 2016

Abstrakte metoder og klasser. Abstrakte metoder og klasser

INF1010 Binære søketrær ++

UNIVERSITETET I OSLO

INF1010 våren Arv og subklasser del 1

Algoritmer og datastrukturer Kapittel 11 - Delkapittel 11.2

Repetisjon. INF gruppe 13

INF1010 Rekursive metoder, binære søketrær. Algoritmer: Mer om rekursive kall mellom objekter Ny datastruktur: binært tre

INF1000: Forelesning 11. Oppgave 2. Oppgave 1. Husk å melde deg på prøveeksamen i INF1000! Ole Christian Lingjærde 7.november 2006

INF1010 våren Arv og subklasser - del 2

Repitisjonskurs. Arv, Subklasser og Grensesnitt

Hva er en liste? Hvert element har en forgjenger, unntatt første element i listen. Hvert element har en etterfølger, unntatt siste element i listen

Kapittel 9: Sortering og søking Kort versjon

EKSAMEN I FAG TDT4100 Objekt-orientert programmering. Fredag 3. juni 2005 KL

INF1010 våren Arv og subklasser - del 2

Lenkelister. Lister og køer. Kopi av utvalgte sider fra forelesningen.

UNIVERSITETET I OSLO

import java.io.*; import java.util.*; import javagently.text;

Liste som abstrakt konsept/datatype

Det finnes ingenting. som kan gjøres med interface. men som ikke kan gjøres uten

IN2010: Algoritmer og Datastrukturer Series 2

INF2100. Oppgaver 26. september til 1. oktober 2007

Introduksjon til objektorientert. programmering. Hva skjedde ~1967? Lokale (og globale) helter. Grunnkurs i objektorientert.

UNIVERSITETET I OSLO

Eksekveringsrekkefølgen (del 1) Oppgave 1. Eksekveringsrekkefølgen (del 2) Kommentar til oppgave 1. } // class Bolighus

LITT OM OPPLEGGET. INF1000 EKSTRATILBUD Stoff fra uke September 2012 Siri Moe Jensen EKSEMPLER

INF Uke 10. Ukesoppgaver oktober 2012

De neste ukene. INF1000 Uke 12. Prøveeksamen. Nå - Prøveeksamen. Forelesning om IT og samfunn neste uke (13/11).

Løsningsforslag, inf101, våren 2001

Transkript:

INF1010, 21. februar 2013 Om å gå gjennom egne beholdere (iteratorer) Stein Gjessing Inst. for Informatikk Universitetet i Oslo

Ikke noe nytt her From the Java language specification (version 6): 14.14.2 The enhanced for statement The enhanced for statement has the form: EnhancedForStatement: for ( VariableModifiers opt Type Identifier: Expression) Statement The Expression must either have type Iterable or else it must be of an array type ( 10.1), or a compile-time error occurs. Kalles også "for-each 2

String-array Ikke noe nytt her class Hoved { public static void main (String [ ] args) { String [ ] alles = { Ole", Eva", Lise", Per", Turid", Anne" for (String s: alles) System.out.println(s); String [ ] alles Ole Eva Anne Akvarium med array class Hoved { public static void main (String [ ] args) { Fisk[ ] allef = {new Fisk("Langen"), new Fisk("Slanken"), new Fisk("Lynet"), new Fisk("Latsabb"), new Fisk("Dorsken"), new Fisk("Storhodet"); Fisk [ ] allef for (Fisk f: allef) System.out.println(f.navn); class Fisk { String navn; Fisk (String nv) {navn = nv; 3

Ikke noe nytt her Akvarium med HashMap import java.util.*; class Hoved { static String [ ] allenavn = { Rar", Slanken", Lynet", Pigg", Dorsken, Stor ; public static void main (String [ ] args) { HashMap<String,Fisk> akvarium = new HashMap<String,Fisk>(); Navn: f Type: Fisk for (int i = 0; i < 6; i++) { Fisk f = new Fisk(alleNavn(i)); akvarium.put(f.navn, f); for (Fisk f: akvarium.values() ) System.out.println(f.navn); class Fisk { String navn; Fisk (String nv) {navn = nv; 4

Hvordan skal vi klare å gå gjennom alle objektene i vår egendefinerte beholder? public void legginn (T en) public T hentut( ) alle [antall] = peker; antall ++; antall --; return alle [antall]; Navn: antall Type: int T [ ] alle Iterable<T> iterergjennomalle()????? NB! slike objekter finnes ikke!! (T må få en verdi først) 5

EnhancedForStatement: for ( VariableModifiers opt Type Identifier: Expression) Statement The Expression must either have type Iterable or else it must be of an array type ( 10.1), or a compile-time error occurs. Type: Iterable<T> Navn: alle Iterator<T> iterator( ) Da kan vi si: for (T en: alle) { <gjør noe med objektet som en peker på> Men T må byttes ut med et ordentlig klassenavn 6

7

Type: Iterable<T> Iterator<T> iterator( ) Navn: alle Type: Iterator<T> Navn: anonym boolean hasnext ( ) T next ( ) void remove ( ) Vi kan da si: for (T en: alle) { <gjør noe med objektet som en peker på> Men T må byttes ut med et ordentlig klassenavn 8

9

Iterasjon over innholdet i en generisk beholder vi lager selv n La oss starte med å gå gjennom alle elementene i en beholder som bare kan inneholde en ting void legginn (T en) T hent( ) Type: T Navn: denne Iterable<T> iterergjennomalle() Objekt av klassen T eller en subklasse av T NB! slike objekter finnes ikke!! 10

class Hoved { public static void main (String [ ] args) { EgenDefBeholder<Fisk> akvarium = new EgenDefBeholder<Fisk> (); akvarium.put(new Fisk("Dorsken")); akvarium for (Fisk f: akvarium.iterergjennomalle() ) System.out.println(f.navn); class Fisk { String navn; Fisk (String nv) {navn = nv; class EgenDefBeholder<T> { private... public void legginn(t en) {... T hent ( ) {... Iterable<T> iterergjennomalle ( ) {... void legginn (Fisk en) Fisk hent( ) Type: Fisk Navn: denne Iterable<Fisk> iterergjennomalle() 11

class Hoved { Enda klarere (?): public static void main (String [ ] args) { GenBeholderTilEn<Fisk> akvarium = new GenBeholderTilEn<Fisk> (); akvarium.put(new Fisk("Dorsken")); akvarium Itarable<Fisk> alle = akvarium.iterergjennomalle(); for (Fisk f: alle) System.out.println(f.navn); class Fisk { String navn; Fisk (String nv) {navn = nv; class GenBeholderTilEn<T> { private... public void legginn(t en) {... T hent ( ) {... Iterable<T> iterergjennomalle ( ) {... void legginn (Fisk en) Fisk hent( ) Type: Fisk Navn: denne Iterable<Fisk> iterergjennomalle() alle Iterable<Fisk> Objekt som implementerer grensesnittet Iterable<Fisk> Iterator<Fisk> iterator( ) 12

public class GenBeholderTilEn <T> { private T denne; public void legginn (T en) { denne= en; public T hent () { return denne; Gammel del public Iterable<T> iterergjennomalle() {return new Ukjent1(); private class Ukjent1 implements Iterable<T> { public Iterator<T> iterator () {return new Ukjent2(); Ny del private class Ukjent2 implements Iterator<T> { boolean fortsett = true; public boolean hasnext(){return fortsett; public T next() {fortsett = false; return denne; public void remove ( ) { class Hoved { public static void main (String [ ] ards) { GenBeholderTilEn<Fisk> ensligakvarium = new GenBeholderTilEn<Fisk> (); ensligakvarium.legginn(new Fisk("Piraja")); for (Fisk f: ensligakvarium.iterergjennomalle()) System.out.println("Fisk med navn: " + f.navn); class Fisk { String navn; Fisk(String nvn) {navn= nvn; 13

public void legginn (Fisk en) public Fisk hent( ) public Iterable<Fisk> iterergjennomalle() {return new Ukjent1(); Type: Fisk Navn: denne Iterator iterator( ) return new Ukent2(); objekt av class Ukjent1 implements Iterable<Fisk> boolean hasnext( ) Fisk next( ) void remove( ) fortsett objekt av class Ukjent2 implements Iterator<Fisk> Navn: ensligakvarium Type: GenBeholderTilEn<Fisk> Når java kjører er objektene i virkeligheten ikke inne i hverandre (men det blir letter for oss hvis vi tenker oss at de er inne i hverandre) 14

Iterasjon over innholdet i en større generisk beholder n Hvis vi ungår pirajaen, kan vi bruke et akvarium som kan inneholde mange fisk n Vi lager først en generisk beholder med plass til mange objekter 15

tenkt objekt av klassen Beholder<T> public void legginn (T en) public T hent( ) alle [antall] = peker; antall ++; antall --; return alle [antall]; public Iterable<T> iterergjennomalle() {return new Ukjent1(); Navn: antall Type: int T [ ] alle Iterator<T> iterator( ) return new Ukjent2(); objekt av class Ukjent1 implements Iterable<T> boolean hasnext( ) return teller < antall; T next( ) teller teller ++; return alle[teller-1]; void remove( ) objekt av class Ukjent2 implements Iterator<T> NB! slike objekter finnes ikke!! 16

objekt av klassen Beholder<Fisk> public void legginn (Fisk en) public Fisk hent( ) alle [antall] = peker; antall ++; antall --; return alle [antall]; public Iterable<Fisk> iterergjennomalle() {return new Ukjent1(); Navn: antall Type: int Fisk [ ] alle Iterator<Fisk> iterator( ) return new Ukjent2(); objekt av class Ukjent1 implements Iterable<Fisk> boolean hasnext( ) return teller < antall; Fisk next( ) teller teller ++; return alle[teller-1]; void remove( ) objekt av class Ukjent2 implements Iterator<Fisk> NB! slike objekter finnes!! 17

class Hoved{ public static void main (String [ ] ards) { new Hoved ( ); Hoved() { String [ ] allenavn = { "Langen", "Slanken", "Lynet", "Latsabb, "Dorsken", "Storhodet"; Beholder<Fisk> akvarium = new Beholder<Fisk>(); for (int i = 0; i < 6; i++) { Fisk f = new Fisk(alleNavn[i]); akvarium.legginn(f); for (Fisk fsk: akvarium.iterergjennomalle()) System.out.println("Fisk med navn: " + fsk.navn); class Beholder<T> { int antall = 0; T[] alle = (T[]) new Object[100]; void legginn(t peker) {alle [antall] = peker; antall ++; T hent () {antall --; return alle [antall]; Iterable<T> iterergjennomalle() {return new Ukjent1(); class Ukjent1 implements Iterable<T> { public Iterator<T> iterator () {return new Ukjent2(); class Ukjent2 implements Iterator<T> { int teller = 0; public boolean hasnext(){return teller < antall; public T next() {teller ++; return alle[teller-1]; public void remove ( ) { class Fisk { String navn; Fisk(String nvn) {navn = nvn; 18

class Hoved { public static void main (String [ ] ards) { String [ ] navn = { Ole", "Per", "Paal", "Eva", "Else"; for (String s: navn) System.out.println(s); import java.util.iterator; Repetisjon Ikke nytt Enkel måte å gå gjennom en String-tabell Komplisert måte å gå gjennom en String-tabell class Hoved2 { public static void main (String [ ] ards) { new Hooved2 ( ); Hoved2() { for (String s: new Ukjent1()) { System.out.println(s); String [ ] navn = { "Ole", "Per", "Paal", "Eva", "Else"; class Ukjent1 implements Iterable<String> { public Iterator iterator () {return new Ukjent2(); class Ukjent2 implements Iterator<String> { int teller = 0; public boolean hasnext(){return teller!= navn.length; public String next() {teller ++ ; return navn[teller-1]; public void remove ( ) { Nytt i dag Slike indre klasser (som ikke er static ) finnes bare inne i objekter (ikke inne i klassedatastrukturer) 19

HashMap og grensesnittet Collection public interface Collection<E> extends Iterable<E> {..... class HashMap<K,V>... { <Hemmelig datastruktur> private class Ukjent1 implements Collection<V> {... private class Ukent2 implements Iterator <V> {... public void put(k nokkel, V verdi ){...... public Collection<V> values( ) { Ukjent1<V> u = new Ukjent1<V> ( ) ;... return u;... HashMap har altså sine egen implementasjon av Collection som er hemmelig for oss utenfor 20

Eks. implementasjon av HashMap HashMap<String, Dokument> alledokumenter void visalledokumenter() for (Dokument d: alledokumenter.values()) { d.vispaaskjerm(); d objekt av class Ukjent1 implements Collection<Dokument> Iterator<Dokument> iterator( ) Collection<Dokument> values() boolean hasnext( ) Dokument next( ) objekt av class Ukjent2 implements Iterator<Dokument> Dokument-objekt 21