Oversikt. Feil i programmet hva skjer? Array indeks utenfor sine grenser. Inf1010 Våren Feilsituasjoner og unntak i Java

Like dokumenter
Inf1010 Våren Feilsituasjoner og unntak i Java. Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Inf1010 Våren Feilsituasjoner og unntak i Java. Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Oversikt. Feil i programmet hva skjer? Array indeks utenfor sine grenser. Inf1010 Våren Feilsituasjoner og unntak i Java

Inf1010 Våren Feilsituasjoner og unntak i Java. Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Oversikt. Array indeks utenfor sine grenser. Feil i programmet hva skjer?

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

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

INF1010 våren 2018 tirsdag 23. januar

INF1010, 8. mars Om klassehierarkier, grensesnitt (interface) og multippel arv. Konstruktører i subklasser. Unntak.

INF1010 våren Arv og subklasser del 1 (pluss litt I/O og unntaksbehandling)

INF1010 våren Arv og subklasser - del 2

INF 1010, vår 2005 Løsningsforslag uke 11

Kapittel 11: Unntakshåndtering. Java som første programmeringsspråk

Kapittel 13: Unntakshåndtering

Kapittel 11: Unntakshåndtering. Java som første programmeringsspråk

Kapittel 13: Unntakshåndtering

Læringsmål for forelesningen

INF1010 våren Generalisering -spesialisering Gjenbruk av klasser. Ved arv. Klasse-hierarkier. Stein Gjessing.

Klasser skal lages slik at de i minst mulig grad er avhengig av at klienten gjør bestemte ting STOL ALDRI PÅ KLIENTEN!

INF1010 våren Arv og subklasser del 1 pluss (hvis vi har tid) litt om Unntak, IO og Scanner-klassen

Leksjon 7. Filer og unntak

Videregående programmering 6

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

Uke 5, 27. januar Arv og subklasser del I. Stein Gjessing Institutt for informatikk

Konstruktører. Bruk av konstruktører når vi opererer med "enkle" klasser er ganske ukomplisert. Når vi skriver. skjer følgende:

INF1000 EKSTRATILBUD. Stoff fra uke 1-5 (6) 3. oktober 2012 Siri Moe Jensen

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

Repetisjon. INF gruppe 13

INF Uke 10. Ukesoppgaver oktober 2012

IN1010. Fra Python til Java. En introduksjon til programmeringsspråkenes verden Dag Langmyhr

Innhold uke 4. INF 1000 høsten 2011 Uke 4: 13. september. Deklarasjon av peker og opprettelse av arrayobjektet. Representasjon av array i Java

UNIVERSITETET I OSLO

Løsningsforslag ukeoppg. 6: 28. sep - 4. okt (INF Høst 2011)

Jentetreff INF1000 Debugging i Java

Forelesning inf Java 5

Forelesning inf Java 5

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

Fra Python til Java. En introduksjon til programmeringsspråkenes verden. Dag Langmyhr

2 Om statiske variable/konstanter og statiske metoder.

IN1010. Fra Python til Java. En introduksjon til programmeringsspråkenes verden Dag Langmyhr

INF1000: noen avsluttende ord

3 emner i dag! INF1000 Uke 5. Objekter og pekere. null. Litt om objekter, pekere og null Filer og easyio Litt mer om tekster

Sortering med tråder - Quicksort

UNIVERSITETET I OSLO

INF1010 våren Arv og subklasser - del 2

INF1010 våren 2008 Uke 4, 22. januar Arv og subklasser

2 Om statiske variable/konstanter og statiske metoder.

Lese fra fil. INF1000 : Forelesning 5. Eksempel. De vanligste lesemetodene. Metoder:

Enkle generiske klasser i Java

INF1010 Eksamenstips. Løsningsforslag prøveeksamen del 1.

(MVC - Model, View, Control)

INF1010 våren Arv og subklasser, del 2

TOD063 Datastrukturer og algoritmer

UNIVERSITETET I OSLO

IN Notat om I/O i Java

Innlesning fra tastatur med easyio. INF1000 høst Vi må først skrive i toppen av programmet: import easyio.*;

Forkurs INF1010. Dag 1. Andreas Færøvig Olsen Tuva Kristine Thoresen

Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister

Forelesning inf Java 4

i=0 Repetisjon: arrayer Forelesning inf Java 4 Repetisjon: nesting av løkker Repetisjon: nesting av løkker 0*0 0*2 0*3 0*1 0*4

INF1000 (Uke 4) Mer om forgreninger, While-løkker

Gjennomgang av eksamen H99

Blokker og metoder INF1000 (Uke 6) Metoder

Tre måter å lese fra terminal. Java 4. Eksempel. Formatert utskrift til skjerm

Oblig 4Hybelhus litt mer tips enn i oppgaven

INF1000 : Forelesning 4

INF1000 (Uke 5) Mer om løkker, arrayer og metoder

UNIVERSITETET I OSLO

INF1000 (Uke 6) Mer om metoder, tekster

INF1000: Forelesning 7. Konstruktører Static

I dag INF1000 (Uke 4) Mer om forgreninger, While-løkker. Tre måter å lese fra terminal. Repetisjon. Mer om forgrening While-løkker

Array&ArrayList Lagring Liste Klasseparametre Arrayliste Testing Lenkelister Videre

i=0 i=1 Repetisjon: nesting av løkker INF1000 : Forelesning 4 Repetisjon: nesting av løkker Repetisjon: nesting av løkker j=0 j=1 j=2 j=3 j=4

Rep: Metoder. INF1000 (Uke 6) Mer om metoder, tekster. Rep: Metoder. 3 typer variable: Klassevariable. Java-programmene så langt i kurset:

INF1000: Forelesning 7

UNIVERSITETET I OSLO

I dag INF1000 (Uke 4) Mer om forgreninger, While-løkker. Tre måter å lese fra terminal. Tre måter å lese fra terminal.

INF1000 : Forelesning 3

Forelesningsquiz. Forelesning inf Java 5. Sett dere to (eller tre) sammen og besvar de fire spørsmålene på utdelt ark. Tid: 15 min.

INF2100. Oppgaver 26. september til 1. oktober 2007

INF1000: noen avsluttende ord

D Feilhåndtering og unntaksklasser

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

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

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

INF1000: Forelesning 6. Klasser og objekter del 1

Spørsmål fra forrige forelesning. INF1000 Forelesning 7. Oppførselen til inword()/inint()/etc. Operator-presedens i Java

Oblig 4 (av 4) INF1000, høsten 2012 Værdata, leveres innen 9. nov. kl

Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Fra Python til Java, del 2

Ta inn og ut av 2D-array. Java 6. Liste over ulike verdier i 2D-array. Det ferdige programmet. Vi skal lage et program som illustrerer hvordan man

IN1010 våren 2018 Tirsdag 6. februar. Arv og subklasser - del 2

Avdeling for ingeniørutdanning Institutt for teknologi

INF1010 våren 2017 Torsdag 2. februar. Arv og subklasser - del 2

UNIVERSITETET I OSLO

INF Notater. Veronika Heimsbakk 10. juni 2012

IN 211 Programmeringsspråk. Java. på 20 enkle ark. spesielt for de som kan. Simula. (og gjerne litt C) Ark 1 av 20

Body Mass Index (BMI) INF1000 : Forelesning 3. Ferdig program (forts.) Ferdig program

Hvis en person har inntekt < , så betaler han 10% skatt på alt, og ellers betaler han 10% skatt på de første og 30% på resten.

Transkript:

Oversikt Inf1010 Våren 2008 Feilsituasjoner og unntak i Java Stein Gjessing, Institutt for informatikk, Universitetet i Oslo Hva er en feil (er det ikke mulig å unngå feil?) Hva skjer når et program feiler Mål 1: Å ikke få feilmeldinger fra kjøretidsystemet, men isteden la programmet få kontrollen tilbake etter en feilsituasjoen: Der programmet normalt ville ha avsluttet med en feilmelding Eks: Divisjon med null, greier ikke åpne en fil, filen finnes ikke, knytte kontakt over nettet mislykkes, utenfor arraygrensen Mål 2: Enklere, mer vedlikeholdbar og mer forstålig kode 2 Feil i programmet hva skjer? import easyio.*; class Feil1 { public static void main(string[] args) { In tast = new In(); int i = 1, j = 1; Array indeks utenfor sine grenser int [ ] tallvektor; tallvektor = new int [100]; tallvektor[101] = 17; while ( i >= 0) { System.out.print("\n Divisjon: 100 delt på: (gi tall):"); i = tast. inint(); j = 100/ i; System.out.println("Svaret på 100/" + i + " er:" +j); 3 4

Unntak / feil, behandling i Java Mye kode kan feile og feilaktige situasjoner (unntak) kan oppstå. Kode som kan feile kan - og som oftest må - vi legge følgende rundt: Fem nye Java ord try - Står foran en blokk som er usikker dvs. der det kan oppstå et unntak catch - Står foran en blokk som behandler et unntak. Har en peker til et unntaksobjekt som parameter finally - blir alltid uført Kode som kan feile Feiler koden blir denne blokken kalt med feilobjektet e som parameter... Kode som kan feile...; catch (Exception e) {... Gjør noe med feilen, prøv å rett opp... finally { Blir alltid utført throw - Starter å kaste et unntak throw <en peker til et unntaksobjekt> f.eks throw new Unntak(); throws - Kaster et unntak videre Brukes i overskriften på en metode som ikke selv vil behandle et unntak Bruk: <usikker kode> catch (Unntaksklasse u) { <behandle unntaket, u peker på et objekt som beskriver unntaket> finally { rydd opp 5 6 Unntaksbehandling <USIKKER KODE> <Hvis det skjer noe galt:> throw new Unntaksklasse( );.... catch (Unntaksklasse unt) { < Unntaksbehandling. Dette hoppes over når intet unormalt/galt har hendt > finally { hit kommer programmet alltid < her fortsetter programmet både etter normal utføring og etter behandling av eventuelle unntak, men ikke når et unntak er kastet uten at det er fanget> Enkleste form for unntaksbehandling. På forhånd har vi deklarert: class Unntaksklasse extends Exception {... 7 A a Når unntak oppstår i en metode og ikke behandles der.... x = b ( );.... catch (Unntaksklassen unt) { < Unntaksbehandling. Dette hoppes over når intet unormalt har hendt > finally { hit kommer programmet alltid < her fortsetter programmet både etter normal utføring og etter behandling av eventuelle unntak, men ikke hvis unntaket blir kastet videre> int b( ) throws Unntaksklassen { a kaller b b oppdager en feil: throw new Unntaksklassen ( ) ; Normal retur fra b til a: return 17; Unntaksklassen er en klasse som vi på forhånd har deklarert som en subklasse av klassen Exception. 8

Vimå ikke gjøre noe med feil/unntak (throws) Unntak - oversikt Vi kan bare sende dem videre til den metoden som kalte oss: throws (og helt til kjøresystemet: > java hvis det er main som kaster unntak/feilmeldinger videre). Vi må da etter metodens parameter-parentes, men før begynnende krøll-parentes, skrive: throws UnttakType1, UnntakType2,... { hvor UnttakType1, UnntakType2,... er de typer (klassenavnene) på de unntak som oppstår (eller superklasser av disse, f.eks. Exception) og ikke selv fanger med try-catch. Merk at vi bruker ordet både for unntak metoden vår selv genererer og de unntak/feil metoden mottar (fra metoder den selv har kalt) og bare videresender. Ulempe med videre-kasting av unntak: Jo nærmere feilkilden feilen blir rettet, jo bedre. Brukes til å fange feil - eller uvanlige situasjoner Når en feilsituasjon oppstår: Lages det et objekt Dette objektet brukes av feilbehandlingen som enten skjer I samme metode (try-catch) eller blir sendt tilbake til kallende metode (throws) Vi må ikke (men kan) behandle feil av typen: Feil og feil fru Blom RunTimeException Artimetriske feil Array-grense-feil Behandler vi ikke slike feil, avsluttes programmet av runtime-systemet Error Grusomme systemfeil vi ikke kan gjøre noe med 9 10 Hvilke klasser av feil og unntak har vi i Java Klassehierarki unntak Exception unntak (med alle subklassene) Disse unntakene kan og må vi fange (Unntatt RunTimeException) F.eks. IOException (kommer vi tilbake til) RunTimeException (en subklasse av Exception) igjen med sine subklasser som : ArrayIndexOutOfBoundsException, NumberFormatException, ArithmeticException,... Disse kan, men må vi ikke fange Vi kan, men må ikke skrive try-catch for disse feilsituasjonene Vi kan kort sagt ignorere disse (men da terminerer programmet ) Det ville ellers bli alt for mye..catch (..){... i koden Eks: Divisjon med 0, en peker er null, gal indeks i en array,.. Error (med alle subklassene) Noe galt skjer, vi kan som oftest ikke gjøre noe med det Eks:.InternalError.OutOfMemoryError, NoClassDefFoundError Error og Exception er subklasser av Throwable Vanskelig å gjøre noe med Error VirtualMachineError NullPointerException Throwable RuntimeException IOError Exception ArithmeticException IOException Må fanges 11 12

Sende feilene videre ut av main throws (ulempe programmet bare avslutter) Unntak strategier import easyio.*; class MinFeil extends Exception { MinFeil (String s) { super(s); class Feil { int i; public static void main(string[] args) throws ArrayIndexOutOfBoundsException, NumberFormatException, MinFeil { int j; j = new Feil().a(args[0]); System.out.println("RIKTIG: j = + j); int a (String s) throws NumberFormatException, MinFeil { int i = Integer.parseInt(s); if (i < 10) throw new MinFeil ("FEIL: Tallet er mindre enn 10"); return i; Flere måter å behandle unntak/avbrudd: 1. Løs problemet og kall metoden som ga unntak om igjen 2. Lapper sammen ting uten å kalle metoden som ga unntak, eller beregn et alternativt ( beste ) resultat istedenfor det unntaksmetoden skulle ha beregnet 3. Avslutt programmet: System.exit(0); 4. Ignorere dem hvis de er av typen RunTimeException eller Error hvis de oppstår terminerer programmet F.Eks ArrayIndexOutOfBoundsException og NumberFormatException behøver ikke deklareres (er RuntimeExceptions, dvs. kan utelates fra throws ) 13 14 Unntak - oversikt, forts. 5. Kaste det videre f.eks. public static void main(...) throws IOException når main kaster en feil videre er det til kjøretidsystemet og programmet terminerer 6. Ta imot / fange det og behandle det ferdig:... farlig kode. catch ( Exception e) {... gjør noe fornuftig og rett opp feilen finally { behandle alt annet 7. Ta imot, gjøre noe/litt og så kaste det (eller et annet) videre:... farlig kode. catch ( Exception e ) {... gjør noe fornuftig, f.eks. rett opp litt av feilen og så throw e; finally { behandle alt annet String-indeks utenfor stringen class Unntak0x { public static void main(string[ ] args) { new Unntak0x ( ); Unntak0x ( ) { String s = "Dette er en tekst med 29 tegn", s1; s1 = s.substring(30,32); // string-indeks utenfor "enden" 15 16

Behandler Stringindeks-feil Eksempel på bruk av unntaksobjektet class Unntak1x { public static void main(string[ ] args) { new Unntak1x ( ); Unntak1x ( ) { String s = "Dette er en tekst med 29 tegn", s1; s1 = s.substring(30,32); // string-indeks utenfor "enden" catch (StringIndexOutOfBoundsException e) { System.out.println("Her er det noe galt med string-indeksen ); //end try >java Unntak1x Her er det noe galt med string-indeksen class Unntak2x { public static void main(string[ ] args) { new Unntak2x ( ); Unntak2x ( ) { String s = "Dette er en tekst med 29 tegn", s1; s1 = s.substring(30,32); // string-indeks utenfor "enden" catch (StringIndexOutOfBoundsException e) { System.out.println("Her er det noe galt med string-indeksen " + e.getmessage( )); //end try >java Unntak2x Her er det noe galt med string-indeksen String index out of range: 32 17 18 Fange divisjon med 0 Starte å sende feil/unntak selv - eks. public class TryTest { public static void main ( String [ ] args) Her tar programmet { int i=1; seg av hele feilen for (int j=0; j < 5; j++) try{ i = 10/j; System.out.println("Det gikk OK, i:" + i + ", j:" + j); catch (Exception e) { System.out.println("Feil i uttrykk: "+ e.getmessage( )); // end TryTest snidil> java TryTest Feil i uttrykk: / by zero Det gikk OK, i:10, j:1 Det gikk OK, i:5, j:2 Det gikk OK, i:3, j:3 Det gikk OK, i:2, j:4 snidil> 19 class Feil1 { int i; public static void main(string[] args) { new Feil1().a(null); void a( Feil1 pek) { if (pek == null ) throw new NullPointerException( pek må være!= null"); pek.i = 14; Merk at her kastes et objekt av en klasse som er subklasse av RunTimeException, så da trenger vi ikke try-catch rundt kallet på metoden a 20

Egendefinerte unntak Eksempel Konto med OvertrekkUnntak - VIKTIG class Mittunntak extends Exception { public Mittunntak ( ) { public Mittunntak (String s) { super(s); // end konstruktører // end class Mittunntak try{... catch (Mittunntak e) {.. e.getmessage( ).. throw new Mittunntak("feilmelding"); throw new Mittunntak( ); Den nye klassen Mittunntak utvider (extends) den ferdiglaget Java-klasse med navn Exception. 21 class Konto { private double saldo = 0, minimumsaldo = 0; private int kontonr; Konto (int nr) { kontonr = nr; public void taut (double belop) throws OvertrekkUnntak { if (saldo - belop < minimumsaldo) { throw new OvertrekkUnntak(Integer.toString(kontonr)); else saldo = saldo - belop; // slutt taut... class OvertrekkUnntak extends Exception { public OvertrekkUnntak (String s) { // slutt Konto super(s); // end class OvertrekkUnntak 22 Bruk av Konto med OvertrekkUnntak Flere opplysninger ut av parameteren til catch class Bank{ static void main (String [] args) { Konto pek = new Konto(234); pek.taut(-10); catch (OvertrekkUnntak e) { System.out.print(" Overtrekk på konto "); System.out.println( e.getmessage()); // slutt catch // slutt main slutt Bank import easyio.*; class Feil3 { public static void main(string[] args) { new Feil3().a(); void a() { b(); void b(){ In tast = new In(); int i = 1, j = 0; while ( i >= 0) { System.out.print("\nDivisjon: 100 delt på: (gi tall):"); i = tast. inint(); Divisjon: 100 delt p: (gi tall):0 FY - deling med null er tull java.lang.arithmeticexception: / by zero at Feil3.b(Feil3.java:19) at Feil3.a(Feil3.java:9) at Feil3.main(Feil3.java:6) Divisjon: 100 delt p: (gi tall): try{ j = 100/ i; System.out.println("Svaret på 100/" + i + " er:" +j); catch (Exception e){ System.out.println("\n FY - deling med null er tull"); e.printstacktrace(); 23 24

Fange flere unntak Flere catch pluss finally class Unntak3x { public static void main(string[ ] args) { new Unntak3x ( ) ; Unntak3x ( ) { int dividend=7, divisor = 0; int kvotient=0; String s="dette er en tekst med 29 tegn"; String s1="*********"; s1 = s.substring(15,17); // OK string-indeks kvotient = dividend/divisor; // Feil: divisjon med 0 catch (StringIndexOutOfBoundsException e) { System.out.println("Her er det noe galt med string-indeksen"); catch (ArithmeticException e1) { System.out.println("Divisjon med 0: " + e1.getmessage( ) ); //end try-catch System.out.println(s1); System.out.println(kvotient); >java Unntak3x Divisjon med 0: / by zero st 0 25 Vi kan ha flere catch etter hverandre:... Kode som kan gi unntak / feile... catch (Type1 t1 ) { catch (Type2 t2 ) {... catch (Type3 t3 ) {... finally { // Dette gjøres alltid - selv om unntaket ikke blir behandlet Da testes det (omlag som en switch), og bare den første som får tilslag, blir utført Husk: At hvis en av klassenavnene (Type1, Type2,..) er superklasse til det innkomne unntaket, vil den blir utført. Finally vil alltid bli utført enten det ble unntak eller ikke og enten noen av catchene fikk tilslag eller ikke Spesielt viktig å ha med hvis unntak blir kastet direkte videre 26 Motta mange feiltyper - eksempel Eksempel: class In og InExp i easyio import easyio.*; class MinFeil extends Exception { MinFeil (String s) { super(s); class Feil7 { int i; int a( String s) throws NumberFormatException, MinFeil{ int i = Integer.parseInt(s); if (i < 10) throw new MinFeil ("FEIL: Tallet er mindre enn 10"); return i; public static void main(string[] args) { int j; j= new Feil7().a(args[0]); System.out.println("RIKTIG: j="+j); catch (ArrayIndexOutOfBoundsException e) { System.out.println("Galt kall på Feil7, bruk:>java Feil7 tall "); catch (NumberFormatException e) { System.out.println("Skriv tall"); catch (MinFeil m) { System.out.println(m.getMessage()); m.printstacktrace(); finally { // Dette gjøres alltid - selv om vi ikke får noe unntak System.out.println("Alltid finally"); 27 3 4 1 2 public class InExp { BufferedReader in;... public int inint(string sep) throws NumberFormatException, IOException { return Integer.parseInt(inWord(sep)); public String inword(string sep) throws IOException { lineno++; return in.readline(); public class In extends InExp { public int inint() { return inint(null); public int inint(string sep) { for (int i = 0; i < numtry; i++) { return super.inint(sep); catch (IOException ioe) { feil("inint: " + ioe.getmessage()); return 0; // kompilatormat catch (NumberFormatException nfe) { System.out.print("Forventer et heltall. Prøv igjen: "); // end try-catch... 28

Oppsummering unntak i Java Hvis det oppstår en feil under kjøring av programmet, kastes det et unntak: throw new Unntaksklasse(); Metoder kan enten kaste unntak videre (throws( )) eller fange opp unntak med try/catch. Dette gjøres ved hjelp av en try/catch-blokk:... usikker kode... catch(exceptionnavn e) {... finally {... Det bør alltid være med en finally-blokk som rydder opp. Unntak kastes oppover i kallkjeden inntil det blir fanget opp. Metoder som kaster unntak videre, må deklare dette ved hjelp av nøkkelordet throws: metodenavn(...) throws ExceptionNavn Metoder som kaster unntak som tilhører RuntimeException-klassen, trenger ikke å deklarere dette. Et unntak som ikke blir fanget opp av en metode underveis, blir til slutt fanget opp av kjøresystemet til Java, som skriver ut relevant informasjon om unntaket og avslutter programmet. Java og C# Vi har tidligere snakket litt om forskjellene mellom Java og C# Java er laget av Sun, C# av Microsoft Det meste er likt Hendelser håndteres forskjellig Unntak håndteres rimelig likt, men i C# er du ikke tvunget til å deklarere de unntak som kastets videre (alle unntak I C# fungerer altså slik som runtime-feil i Java) Alle Microsofts språk kompileres til C# og bruker C#s objektorienterte kjøretidsystem Java compileres til byte-kode, C# kompileres Just-In-Time (JIT) til maskinkode 30