Sammanfattning. Sammanfattning, arrayer, inre och nästlade klasser, undantagshantering, wrapperklasser mm. Metodefinition
|
|
- Solveig Olofsson
- för 8 år sedan
- Visningar:
Transkript
1 Sammanfattning Sammanfattning, arrayer, inre och nästlade klasser, undantagshantering, wrapperklasser mm Tobias Wrigstad (baserat på material från Tom Smedsaas) 9 november 2010 public class TheClassName { variable declaration (instances and classes) method declarations (instances and classes) Ingen speciell ordning krävs men... Instansvariabler skall i regel inte vara åtkomliga av utomstående (private) Instansvariabler har defaultvärden beroende på typ (typiskt 0 eller null för referensvariabler) Instansvariabler kan initieras i deklarationen till godtyckliga uttryck (variabler i sådana uttryck måste vara definierade) Forward-referenser i initiering är inte tillåtna public class InstvarOrder { int i = j; int j = 7; dhcp :temp tobias> javac InstvarOrder.java InstvarOrder.java:2: illegal forward reference int i = j; ˆ public class InstvarOrder { int j = 7; int i = j; dhcp :temp tobias> javac InstvarOrder.java dhcp :temp tobias> Metodefinition åtkomstmodifierare ReturTyp metodnamn(typ1 param1,, TypN paramn) { lokala variabler, satser och eventuell värderetur Modifierarna anger t.ex. synlighet, klass/instansmetod Lokala variabler har inga defaultvärden utan måste tilldelas före användning I metoder som har en returtyp som inte är void måste alla möjliga vägar genom metoden sluta med return exp där exp är ett uttryck av den aktuella returtypen Metoder kan ha samma namn om de har olika signatur dvs skiljer sig i parameterantal och/eller typ (överlagring) undvik detta i möjligaste mån, förutom för konstruktorer
2 Metodanrop exp.metodnamn(arg1,, argn); där exp är ett uttryck som returnerar en referens (ett värde av referenstyp) Exempel: this.setname(first + last) (first + last).length() first.trim().substring(0,7).length() somemethod() I det sista fallet kommer somemethod() att bindas till antingen en instansmetod (=this.somemethod()) ellerenklassmetod (=MyClass.someMethod()), beroende på vilken som existerar (båda är inte tillåtet i Java) Uttryck i parameterlistan evalueras från vänster till höger Konstruktorer En konstruktor är en metod som körs automatiskt så fort minne allokerats för ett objekt, och instansvariabler tilldelats sina startvärden En konstruktor har alltid samma namn som klassen den tillhör och saknar returtyp Flera konstruktorer i en klass är vanligt för att kunna skapa objekt på flera sätt (t.ex. ström från fil, ström från sökväg) En klass utan konstruktor får en defaultkonstruktor automatiskt vid kompilering av Java-kompilatorn Parameter och resultatöverföring Java har referenssemantik för objekt och värdesemantik för primitiva datatyper. Referenssemantik = referensen till objektet kopieras, kopian pekar ut samma objekt som originalet; ger på så sätt upphov till aliasering Värdesemantik = värdet i variabeln kopieras i sin helhet Aliasering = två variabler som pekar ut samma objekt Minns att pekare inte finns! En variabel i en metod kan inte peka ut ett värde i en variabel i en annan metod. (Motsvarande beteende uppnås enklast med objekt.) Arrayer Arrayer är objekt med attribut och metoder. Eftersom en array är ett objekt hanteras den med referenssemantik vid parameteröverföring och returnering. Deklaration: typ[] namn typ[] namn = exp typ[] namn = {v 0,v 1,,v n där v i godtyckligt beräkningsbart uttryck av rätt typ. Instantiering: new RefTyp[47]; // skapar en array av 47 referenser new int[4]; // skapar en array av 4 intar new boolean[2] {true, false;
3 Exempel public class Circles { private Circle[] circles; private int numberofcircles = 0; public Circles() { circles = new Circle[5]; public void add(circle c) { circles[numberofcircles++] = c; public static void main(string[] args) { Circles circles = new Circles(); Point p = new Point(0,0); for (int i = 1; i<=10; i++) circles.add(new Circle(p, 10*i)); kursa$ java Circles java.lang.arrayindexoutofboundsexception: 5 at Circles.add(Compiled Code) at Circles.main(Compiled Code) kursa$ En bättre add-metod, och några observationer public class Circles { private Circle [] circles; private int numberofcircles; public void add(circle c) { if (circles.length == numberofcircles) { Circle[] _ = new Circle[2*circles.length]; System.arraycopy(circles, 0, _, 0, circles.length); circles = _; circles[numberofcircles++] = c; Attributet length Metoden System.arraycopy Grund kopiering (shallow copy) final-specifikation Klasser, metoder och variabler kan deklareras som final. Här talar vi bara om final-variabler. En variabel som är final måste tilldelas sitt värde vid initiering eller konstruktorn; detta värde kan sedan inte förändras public class Point { public final double x; public final double y; public Point(double x, double y) { this.x = x; this.y = y; Typkonverteringar Java konverterar automatiskt när det kan ske riskfritt Explicit med s.k. typecasts. Ex:(short) Vid aritmetik omvandlas byte, short till int Om en operand är long så omvandlas den andra till long (om den är av heltalstyp) Funktioner i Math returnerar double för att undvika precisionsförlust public Point() { this(0.0, 0.0); // Anropar andra konstruktorn
4 Omslagsklasser Primitiva datatyper kan hanteras effektivt Ibland vill man dock behandla dem som objekt då finns en motsvarande klass för varje primitiv datatyp (t.ex. Integer) Klasserna har oftast samma namn som de primitiva typerna men följer namnprinciperna för klasser. Wrapper-klasserna för int och char heter dock Integer och Character. Dessa klasser innehåller Ett antal klass-attribut med konstanter (t.ex. max och minvärde) Ett antal klass-metoder för t.ex. konverteringar Ett antal instansmetoder motsvarande för ett objekt Exempel: Räkna olika typer av tecken import java.io.*; public class Tecken { public static void main(string[] args ) throws IOException { int nupper=0, nlower=0, nothers=0; char c; BufferedReader inf = new BufferedReader(new InputStreamReader(System.in)); System.out.print(">"); while((c=(char)inf.read())!= \n ) { if (Character.isUpperCase(c)) nupper++; else if (Character.isLowerCase(c)) nlower++; else nothers++; System.out.println("U:" + nupper + ",L:" + nlower + ",O:" + nothers Observerationer på klassen Tecken Scanner-klassen passar inte för att läsa tecken (ingen nextchar ) Använder en BufferedReader som via en InputStreamReader kopplas till System.in. Ett standardsätt. Import av java.io.* code returnerar en int i intervallet eller -1 vid filslut (strömslut) Raden throws IOException i början av main Klassen String Ett objekt ur klassen String motsvarar en följd av tecken Strängkonstanter omges med citationstecken String foo = "Omge strängar med \"-tecken"; Objekt av typen String är oföränderliga (immutable). En strängoperation som har String som returtyp returnerar ett helt nytt strängobjekt. Operatorn + konkatenerar strängar Tecknen i strängen numreras från 0, liksom i en char-array Gå till javadokumentationen och titta vad som finns i klasserna omslagsklasserna! Lägg speciellt märke till metoderna parseint och valueof i Integer och motsvarande i Double.
5 Några metoder i klassen String int length() int compareto(string otherstring) boolean equals(object otherobject) char charat(int index) String substring(int start) String substring(int start, int end) int indexof(char char) int indexof(string string) String replace(char oldchar, char newchar) String touppercase() String tolowercase() Exempel: klassen Palindrom // Läser en följd av "ord" och avgör vilka av dessa som är palindrom import java.util.scanner; public class Palindrom { public static void main(string[] args) { Scanner sc = new Scanner(System.in); while (sc.hasnext()) { String w = sc.next().touppercase(); if (w.equals("stop") w.equals("quit")) break; final int n = w.length(); boolean pal = true; for (int i=0; i < n/2 && pal; i++) { pal &= w.charat(i)!=w.charat(n-1-i); System.out.println(w + "är" (pal? "" : "inte") + "ettpalindrom"); Läs själva i Java-dokumentationen! Arrayer av strängar Parametern till main är ett exempel på en array av strängar. När programmet startas kommer orden på kommandoraden att lagras som element i denna array. Exempel: public class Echo { public static void main(string[] args) { for (int i = 0; i<args.length ; ++i) System.out.print(args[i] + ""); System.out.println(); Med körresultat: kursa$ java Echo hej du glade! hej du glade! kursa$ Konvertering av objekt till String Man kan definiera omvandling av objekt till typen String för t.ex. utskriftsändamål genom att definiera en metod tostring(): public class Circle { private Point center; private double radius; public String tostring() { return "Circle(" + center + "," + radius + ")"; public static void main(string [] args) { Circle c = new Circle(new Point(0.0, 0.0), 1.0); System.out.println(c); kursa$ java Circle Circle(Point@1fa4d404, 1.0) kursa$
6 Dynamiska strukturer (listor, träd... ) i Java // En Stack-mekanism som lagrar heltal public class Stack { private StackNode top = null; public boolean isempty() { return top == null; public void push(int element) { top = new StackNode(element, top); public int pop(){ int _ = top.data; top = top.next; return _; Stackexempel forts (Anm: Java har inbyggda klasser som kan hantera stackar, köer, etc.) public class StackNode { private int data; private StackNode next; public StackNode(int data, StackNode node) { this.data = data; this.next = node; Men: hur skall StackNode se ut? Accessmetoder? Skall StackNode vara public? Stackexempel forts, två (av flera) möjliga lösningar: Låt Stack och StackNode ingå i ett paket och ta bort public från definitionen av StackNode eller Gör StackNode till en inre klass till Stack Stackexempel forts, två (av flera) möjliga lösningar: Låt Stack och StackNode ingå i ett paket och ta bort public från definitionen av StackNode eller Gör StackNode till en inre klass till Stack // fil Stack.java package stack; public class Stack { // fil StackNode.java package stack; class StackNode { public class Stack { private class StackNode { int data; StackNode next; StackNode(int data, StackNode node) { this.data = data; this.next = node; private StackNode top = null;
7 Något om felhantering Olika typer av fel: statisk/dynamisk och syntax/semantik Syntaxfel upptäcks av javac (motsv. stafvel) Semantiska statiska fel upptäcks av kompilatorn (typsystemet, dead code analysis, etc.) Semantiska dynamiska fel upptäcks av den virtuella maskinen, av den egna programkoden (felkontroll, defensiv programmering), av testkod, eller inte alls! felaktiga resultat Liksom många andra språk använder Java en generell mekanism för att hantera dynamiska, semantiska fel: undantag (eng. exceptions) Undantag (exceptions) När programmet/javamaskinen upptäcker att något är fel så avbryts exekveringen och ett undantag genereras Ett undantag är ett objekt som beskriver felet och systemets tillstånd Därefter signalerar systemet att ett fel har inträffat undantaget kastas Exekveringen fortsätter sedan i den del av programmet som förklarat sig beredd att hantera denna typ av undantag. Man säger att en hanterare fångar undantaget. Om ingen hanterare finns används en standardhanterare som avbryter programmet med en felutskrift. Exempel på undantagshantering operation som kan leda till undantag catch (ExceptionTypA e1) { kod som körs om ExceptionTypA kastades catch (ExceptionTypB e2) { Exempel på undantagshantering x = 1/0; catch (ArithmeticException e) { System.err.println("Det blev ett fel: " + e.getmessage()); kod som körs om ExceptionTypB kastades
8 Exempel på att kasta ett undandag 1 public class Die { 2 int sides = -1; 3 public Die(int sides) { 4 if (sides < 2) { 5 throw new IllegalArgumentException("A die must have 2+ sides"); this.sides = sides; new Die(0); catch (IllegalArgumentException e) { Under vilka omständigheter exekveras rad 7 8? Undantagshantering forts Som programmerare måste man i princip alltid tala om vad skall hända om ett fel inträffar. Tre möjligheter: Ta hand om felet ( fånga det ): catch Skicka det vidare: throws Kombination: fånga och skicka vidare Det finns undantag (!) från den obligatoriska felhanteringen s.k. okontrollerade undantag. Rekommendation: använd alltid okontrollerade undantag (unchecked exceptions) Designproblem i Java: checked exceptions leder till dålig kod Exempel på att kasta ett undandag vidare 1 public Die makemeanewdie(int sides) { 2 3 return new Die(sides); 4 catch (IllegalArgumentException e) { 5 // Cannot recover from this error, so pass it on 6 throw e; public Die makemeanewdie(int sides) { 2 return new Die(sides); 3 Vad är skillnaden mellan kodexemplen? Javas undantag är indelade i olika kategorier: Error allvarliga fel som kan inte hanteras av programmeraren Exception RuntimeException (okontrollerade) IndexOutOfBoundsException NegativeArraySizeException NullPointerException ArithmeticException IOException EOFException FileNotFoundException
9 Exempel: För många pop public class StackTest { public static void main(string[] args) { Stack s = new Stack(); s.push(1); s.push(2); s.push(3); while (!s.isempty()) { System.out.println(s.pop()); s.pop(); bellatrix$ java StackTest Exception in thread "main" java.lang.nullpointerexception at Stack.pop(Stack.java:36) at Stack.main(Stack.java:48) bellatrix$ Exempel: Fånga felet från pop s.push(3); while (!s.isempty()) { System.out.println(s.pop()); s.pop(); catch (NullPointerException e) { System.err.println("Hoppla!"); bellatrix> java StackTest Hoppla! Skapa en egen felklass Gör det tydligare vilket problem som avses: public class StackUnderFlowException extends RuntimeException { public String getmessage() { return "The stack was pop d when it was empty"; Modifiering av pop: public int pop() { if (top==null) { throw new StackUnderFlowException(); int r = top.data; top = top.next; return r; Egen felklass forts s.push(3); while (!s.isempty()) { System.out.println(s.pop()); s.pop(); catch (StackUnderFlowException e) { System.err.println("Hoppla!" + e.getmessage()); Med körresultat: bellatrix$ java StackTest Hoppla! The stack was pop d when it was empty bellatrix$
10 Egen felklass forts Två möjliga placering av StackException: I en egen fil i samma katalog som Stack (och i samma paket som Stack) Som en publik nästlad klass i klassen Stack: Skillnad mellan nästlad klass och inre klass En inre klass är kopplad till det omslutande objektet: Stack stack = new Stack(); StackNode stacknode = new stack.stacknode(); // Inside the Stack class, we can simply write new StackNode(), why? public class Stack { public static class StackUnderFlowException extends RuntimeException { private static class StackNode { En nästlad klass är kopplad till den omslutande klassen: while (true) System.out.println(s.pop()); catch (Stack.StackUnderFlowException e) { System.out.println("Hoppla! "+ e.getmessage()); Skillnad mellan nästlad klass och inre klass Alla kontrollerade undantag som kan kastas i en metod måste antingen fångas eller så måste metoden ange att den kan skicka kontrollerade undantag (throws): public String getpath(file somefile) throws IOException { return somefile.getcanonicalpath(); public String getpath(file somefile) { return somefile.getcanonicalpath(); catch (IOException e) { return null;
Hur ser ett Java-program ut?
(27 augusti 2012 Repetitionsmaterial 1 ) Hur ser ett Java-program ut? // Ett första Java-program som skriver // ut ett meddelande på terminalen public class HelloWorld { public static void main(string
Inkapsling tumregler. Åtkomstmodifikatorer, instantiering, referenser, identitet och ekvivalens, samt klassvariabler. public och private
Inkapsling tumregler Åtkomstmodifikatorer, instantiering, referenser, identitet och ekvivalens, samt klassvariabler Tobias Wrigstad (baserat på material från Tom Smedsaas) 5 november 2010 1. Man skall
Lite om felhantering och Exceptions Mer om variabler och parametrar Fält (eng array) och klassen ArrayList.
Institutionen för Datavetenskap Göteborgs universitet HT2009 DIT011 Objektorienterad programvaruutveckling GU (DIT011) Föreläsning 3 Innehåll Lite om felhantering och Exceptions Mer om variabler och parametrar
Att skriva till och läsa från terminalfönstret
Att skriva till och läsa från terminalfönstret Oftast används grafiska komponenter i Java för att kommunicera med användaren (användargränssnitt), men det finns objekt i standardbiblioteken för de tillfällen
Kompilering och exekvering. Föreläsning 1 Objektorienterad programmering DD1332. En kompilerbar och körbar java-kod. Kompilering och exekvering
Föreläsning 1 Objektorienterad programmering DD1332 Introduktion till Java Kompilering, exekvering, variabler, styrstrukturer Kompilering och exekvering Ett program måste översättas till datorns språk
Idag. Javas datatyper, arrayer, referenssemantik. Arv, polymorfi, typregler, typkonvertering. Tänker inte säga nåt om det som är likadant som i C.
Idag Javas datatyper, arrayer, referenssemantik Klasser Arv, polymorfi, typregler, typkonvertering Strängar Tänker inte säga nåt om det som är likadant som i C. Objectorienterad programmering Sida 1 Ett
Programmering med Java. Grunderna. Programspråket Java. Programmering med Java. Källkodsexempel. Java API-exempel In- och utmatning.
Programmering med Java Programmering med Java Programspråket Java Källkodsexempel Källkod Java API-exempel In- och utmatning Grunderna Ann Pan panda@nada.kth.se Rum 1445, plan 4 på Nada 08-7909690 Game.java
Idag. Exempel, version 2. Exempel, version 3. Ett lite större exempel
Idag Ett exempel Undantag Substitutierbarhet, subtyper, subklasser När val av metod beror av typerna hos två objekt Lite om överlagring Exempel, version 2 Notera: för samtliga figurer gäller: arean av
Datatyper och kontrollstrukturer. Skansholm: Kapitel 2) De åtta primitiva typerna. Typ Innehåll Defaultvärde Storlek
De åtta primitiva typerna Java, datatyper, kontrollstrukturer Skansholm: Kapitel 2) Uppsala Universitet 11 mars 2005 Typ Innehåll Defaultvärde Storlek boolean true, false false 1 bit char Tecken \u000
Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2
AID-nummer: Datum: 2014-12-18 Kurskod: 725G61 Provkod: LAB1 Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2 Skrivningstid: 2014-12-18 klockan 8.00-10.00. Hjälpmedel: Inga. För varje fråga
Att deklarera och att använda variabler. Föreläsning 10. Synlighetsregler (2) Synlighetsregler (1)
Föreläsning 10 STRING OCH STRINGBUILDER; VARIABLERS SYNLIGHET Att deklarera och att använda variabler När vi deklarerar en variabel, t ex int x; inför vi en ny variabel med ett namn och en typ. När namnet
Föreläsning 2 Objektorienterad programmering DD1332. Typomvandling
metoder Föreläsning 2 Objektorienterad programmering DD1332 Array [modifierare] String metodnamn (String parameter) Returtyp (utdata typ) i detta fall String Indata typ i detta fall String 1 De får man
Föreläsning 5-6 Innehåll. Exempel på program med objekt. Exempel: kvadratobjekt. Objekt. Skapa och använda objekt Skriva egna klasser
Föreläsning 5-6 Innehåll Exempel på program med objekt Skapa och använda objekt Skriva egna klasser public class DrawSquare { public static void main(string[] args) { SimpleWindow w = new SimpleWindow(600,
public och private Obs: private inte skyddar mot access från andra objekt i samma klass.
public och private En metod som är public får anropas från alla metoder i alla klasser. Ett attribut som är public får avläsas och ändras från alla metoder i alla andra klasser. En metod som är private
Föreläsning 5-6 Innehåll
Föreläsning 5-6 Innehåll Skapa och använda objekt Skriva egna klasser Datavetenskap (LTH) Föreläsning 5-6 HT 2017 1 / 32 Exempel på program med objekt public class DrawSquare { public static void main(string[]
Föreläsning 3-4 Innehåll
Föreläsning 3-4 Innehåll Skriva egna metoder Logiska uttryck Algoritm för att beräkna min och max Vektorer Datavetenskap (LTH) Föreläsning 3-4 HT 2017 1 / 36 Diskutera Vad gör programmet programmet? Föreslå
(Man brukar säga att) Java är... Denna föreläsning. Kompilering av Java. Historik: Java. enkelt. baserat på C/C++ Allmänt om Java
(Man brukar säga att) Java är... Denna föreläsning Allmänt om Java Javas datatyper, arrayer, referenssemantik Klasser Strängar enkelt baserat på C/C++ objekt-orienterat från början dynamiskt utbyggbart
1 Uppgift 1. a) Skapar ett Company-objekt med hjälp av den överlagrade konstruktorn. Du kan själv välja värden på instansvariablerna.
1 Uppgift 1 Klassen Company Banken FinanceTrust som tidigare bara haft privatpersoner som kunder vill nu bygga ut sitt datasystem så att även företag kan registreras som kunder. Skriv klassen Company som
OOP Objekt-orienterad programmering
OOP F6:1 OOP Objekt-orienterad programmering Föreläsning 6 Mer om klasser och objekt Hantera många objekt ArrayList tostring() metoden this Vi vill ofta hantera många objekt i ett program: OOP F6:2 public
Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till bänken.
Tentamen Programmeringsteknik I 2012-06-04 Skrivtid: 1400-1700 Hjälpmedel: Java-bok Tänk på följande Det finns en referensbok (Java) hos tentavakten som du får gå fram och läsa men inte ta tillbaka till
Objektorienterad programmering i Java
Objektorienterad programmering i Java Föreläsning 4 Täcker i stort sett kapitel 6 i kursboken Java Software Solutions 1 Läsanvisningar Den här föreläsningen är uppbyggd som en fortsättning av exemplet
Parsing med Recursive Descent, Avbildningsklasser. Syntaxdiagram. Syntaxdiagram och kodning expression. Betrakta följande uttryck
Betrakta följande uttryck a +(b + c) d + e (f + g h) Parsing med Recursive Descent, Avbildningsklasser Tobias Wrigstad (baserat på bilder från Tom Smedsaas) 22 november 2010 Beräkning med regler: multiplikation
732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Felsökning. Datatyper. Referenstyper. Metoder / funktioner
732G11 Linköpings universitet 2011-01-21 1 2 3 4 5 6 Skapa program Kompilera: Källkod Kompilator bytekod Köra: Bytekod Virtuell maskin Ett riktigt program Hej.java class Hej { public static void main (
LÖSNINGSFÖRSLAG Programmeringsteknik För Ing. - Java, 5p
UMEÅ UNIVERSITET Datavetenskap 010530 LÖSNINGSFÖRSLAG Programmeringsteknik För Ing. - Java, 5p Betygsgränser 3 21,5-27 4 27,5-33,5 5 34-43 Uppgift 1. (4p) Hitta de fel som finns i nedanstående klass (det
Föreläsning 3-4 Innehåll. Diskutera. Metod. Programexempel med metod
Föreläsning 3-4 Innehåll Diskutera Vad gör programmet programmet? Föreslå vilka satser vi kan bryta ut till en egen metod. Skriva egna metoder Logiska uttryck Algoritm för att beräkna min och max Vektorer
Arv: Fordonsexempel. Arv. Arv: fordonsexempel (forts) Arv: Ett exempel. En klassdefinition class A extends B {... }
En klassdefinition class A extends B {... Arv definierar en klass A som ärver av B. Klassen A ärver alla fält och metoder som är definierade för B. A är en subklass till B. B är en superklass till A. class
F4. programmeringsteknik och Matlab
Programmeringsspråk Föreläsning 4 programmeringsteknik och Matlab 2D1312/ 2D1305 Introduktion till Java Kompilering, exekvering, variabler, styrstrukturer 1 Ett program är en eller flera instruktioner
Classes och Interfaces, Objects och References, Initialization
Classes och Interfaces, Objects och References, Initialization Objekt-orienterad programmering och design (DIT953) Niklas Broberg/Johannes Åman Pohjola, 2018 Abstract class En abstract class är en class
OOP Objekt-orienterad programmering
OOP F12:1 OOP Objekt-orienterad programmering Föreläsning 12 Mer om JOptionPane Undantagshantering Vad är det? try catch Kasta egna undantag Filhantering spara objekt mellan körningar Användardialog via
Objektorienterad Programmering (TDDC77)
Objektorienterad Programmering (TDDC77) Föreläsning VI: eclipse, felsökning, felhantering Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2016 Outline Felhantering Eclipse Felsökning Command line argumenter
Command line argumenter. Objektorienterad Programmering (TDDC77) Vad blir resultatet? Nu då? Ahmed Rezine. Hösttermin 2016
Command line argumenter Objektorienterad Programmering (TDDC77) Föreläsning VI: eclipse, felsökning, felhantering Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2016 /* Cla. java * Programmet illustrerar
Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11
Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11 Undantag Engelska: exceptions Skansholm: exceptionella händelser Fel som genereras om man försöker
Föreläsning 12. Föreläsning 12. Rörliga figurer Klassen Timer Undantag Något om applets. Rörliga appletsfigurer Klassen Timer Undantag
Föreläsning 12 Föreläsning 12 Rörliga figurer Klassen Timer Undantag Något om applets Rörliga appletsfigurer Klassen Timer Undantag Något om applets Klassen javax.swing.timer I Swing finns en klass Timer
Outline. Objektorienterad Programmering (TDDC77) Att instansiera en klass. Objekt. Instansiering. Åtkomst. Abstrakt datatyp.
Objektorienterad Programmering (TDDC77) Föreläsning X: Klass diagram, inkapsling, arv Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2017 Att instansiera en klass Objekt I Man instansierar (skapar
TENTAMEN OOP
TENTAMEN OOP 2013-08-08 ANVISNINGAR Påbörja varje ny uppgift på nytt blad. Skriv endast på ena sidan av bladen. Skriv tydligt - oläsbara svar beaktas ej. BETYGSÄTTNING Max antal poäng är 30. För att bli
TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU
TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU På denna föreläsning: Mer om Interface Generiska klasser Undantag Nästlade klasser 1
Testning av program. Verklig modell för programutveckling
Fel i program När man skriver program uppkommer alltid fel. Felen kan indelas i följande kategorier: Under kompileringen upptäcker kompilatorn fel som handlar om att man använt konstruktionerna i programspråket
ITK:P1 Föreläsning 1. Programmering. Programmeringsspråket Java. Stark typning Explicit typning Strukturerat Hög säkerhet
ITK:P1 Föreläsning 1 Att programmera i språket Java DSV Peter Mozelius Programmering Olika typer av programmering som t ex: o Imperativ programmering (C, Pascal m fl) o Funktionell programmering (Lisp,
Objekt, Klasser, Paket m. m.
Objekt, Klasser, Paket m. m. Bildserie 3 Objekt Ett objekt karakteriseras av - Identitet, det som gör det möjligt att särskilja objektet från andra objekt - Tillstånd, den data som finns i objektet - Beteende,
Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11
Objektorienterad programmering i Java Undantag Sven-Olof Nyström Uppsala Universitet Skansholm: Kapitel 11 Undantag Engelska: exceptions Skansholm: exceptionella händelser Fel som genereras om man försöker
Tentamen OOP 2015-03-14
Tentamen OOP 2015-03-14 Anvisningar Fråga 1 och 2 besvaras på det särskilt utdelade formuläret. Du får gärna skriva på bägge sidorna av svarsbladen, men påbörja varje uppgift på ett nytt blad. Vid inlämning
Föreläsning 3 Innehåll. Generiska klasser. Icke-generisk lista ArrayList, skiss av implementering. Icke-generisk lista Risk för fel
Föreläsning 3 Innehåll Generiska klasser Implementera generiska klasser Exceptions Dokumentationekommentarer javadoc Enhetstestning - junit Man kan deklarera en eller flera typparametrar när man definierar
Föreläsnings 9 - Exceptions, I/O
Föreläsnings 9 - Exceptions, I/O Josef Svenningsson Tisdag 6/11 Undantag - Exceptions Kommer ni ihåg det här programmet? Det var ett av de första ni såg i första föreläsningen. import javax.swing.*; public
Uppgiften är att beskriva en kvadrat i ett Java program. En första version av programmet skulle kunna se ut så här:
Att skapa en klass kvadrat Uppgiften är att beskriva en kvadrat i ett Java program. En första version av programmet skulle kunna se ut så här: public class Kvadrat { private int sida; Det var väl inte
Lösningsförslag till omtentamen för TDA540 Objektorienterad Programmering
Lösningsförslag till omtentamen för TDA540 Objektorienterad Programmering Institutionen för Datavetenskap CTH HT-6, TDA540 Dag: 207-0-24, Tid: 4.00-.00 Uppgift a) En abstrakt klass kan inte instansieras,
Det finns en referensbok (Java) hos vakten som du får gå fram och läsa men inte ta tillbaka till bänken.
Tentamen Programmeringsteknik I 2015-03-19 Skrivtid: 14:00 19:00 Hjälpmedel: Java-bok Tänk på följande Det finns en referensbok (Java) hos vakten som du får gå fram och läsa men inte ta tillbaka till bänken.
SMD 134 Objektorienterad programmering
SMD 134 Objektorienterad programmering Dagens agenda: Typer i Java: primitiva datatyperna, referenstyper Variabler och variabeltilldelningar med primitiva typer Konstanter av de olika typerna. Heltalsräkning
DAT043 Objektorienterad Programmering
DAT043 Objektorienterad Programmering Detta är en exempeltenta som innehåller gamla tentauppgifter av ungefär liknande slag som ni kan förvänta er se på ordinarie tenta i Del 1 respektive Del 2. Dock är
Objektorienterad Programmering (TDDC77)
Objektorienterad Programmering (TDDC77) Föreläsning X: Klass diagram, inkapsling, arv Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2017 Outline Instansiering Åtkomst Abstrakt datatyp UML Överlagring
Typkonvertering. Java versus C
Typer Objektorienterad programmering E Typkonvertering Typkonvertering Satser: while, for, if Objekt Föreläsning 2 Implicit konvertering Antag att vi i ett program deklarerat int n=3; double x = 5.2; Då
Lösningsförslag till tentamen för TDA540 Objektorienterad Programmering
Lösningsförslag till tentamen för TDA540 Objektorienterad Programmering Institutionen för Datavetenskap CTH HT-16, TDA540 Dag: 2017-01-09, Tid: 14.00-18.00 Uppgift 1 a) class används för en klassdeklaration
DAT043 Objektorienterad programmering för D, DIT011 Objektorienterad programvaruutveckling för GU
DAT043 Objektorienterad programmering för D, DIT011 Objektorienterad programvaruutveckling för GU lösningsförslag till tentamen 2017-06-09 Tid: 8:30-12:30. Plats: SB. Ansvarig lärare: Fredrik Lindblad,
Föreläsning 5 (6) Metoder. Metoder Deklarera. Metoder. Parametrar Returvärden Överlagring Konstruktorer Statiska metoder tostring() metoden javadoc
Föreläsning 5 (6) Metoder Metoder Parametrar Returvärden Överlagring Konstruktorer Statiska metoder tostring() metoden javadoc Metoder Deklarera public void setnamn(string n) Åtkomstmodifierare Returtyp
Dagens föreläsning. Arrayer och klasser. Medan ni väntar: Gå till m.voto.se/prog11 och svara på några gamla tentamensfrågor! (26 januari 2018 F3 1 )
(26 januari 2018 F3 1 ) Dagens föreläsning Arrayer och klasser Medan ni väntar: Gå till m.voto.se/prog11 och svara på några gamla tentamensfrågor! (26 januari 2018 F3 2 ) Arrayer En array är en datatyp
TDDC30 Programmering i Java, Datastrukturer och Algoritmer Lektion 2. Länkade listor Stackar Köer MyList Iteratorer Lab 2 Exceptions Paket
TDDC30 Programmering i Java, Datastrukturer och Algoritmer Lektion 2 Länkade listor Stackar Köer MyList Iteratorer Lab 2 Exceptions Paket 1 Länkade listor Likadant som i Ada-kursen. 2 Stack MyStack MyStack
Parallellism, återblick
Parallellism, återblick Josef Svenningsson December 11, 2012 Lab7 Det är problem med lab7. Gå med i den grupp som ni använt tidigare. DEMO Flera saker händer samtidigt Ofta hanterar program olika indata
Outline. Objektorienterad Programmering (TDDC77) En frukt har ett namn. Man kan lägga en frukt i en korg... Hashing. Undantag. Ahmed Rezine.
Outline Objektorienterad Programmering (TDDC77) Föreläsning XIV: Undantag, Design Ahmed Rezine IDA, Linköpings Universitet Undantag Design Hösttermin 2017 En frukt har ett namn Man kan lägga en frukt i
Objektorienterad Programmering (TDDC77)
Objektorienterad Programmering (TDDC77) Föreläsning XIV: Undantag, Design Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2017 Outline Hashing Undantag Design Outline Hashing Undantag Design En frukt
Dagens text. Programmeringsteknik. Mer om Scanner-klassen. Dialogrutor (klassen JOptionPane) Bubbelsortering. Omslagsklasser.
(16 februari 2016 F5.1 ) Dagens text Programmeringsteknik Mer om Scanner-klassen Dialogrutor (klassen JOptionPane) Bubbelsortering ArrayList Omslagsklasser Arbetsexempel (16 februari 2016 F5.2 ) Pokertärningar
Tentamen , Introduktion till Java, dtaa98, dtea53
Mittuniversitetet 2007-09-01 Institutionen för informationsteknologi och medier Sid:1(3) dtaa98, dtea53 Martin Kjellqvist; Linda Karlsson, Ulf Reiman Lösningsansatser Tentamen 2007-09-01, Introduktion
Föreläsning 3. Stack
Föreläsning 3 Stack Föreläsning 3 ADT Stack Stack JCF Tillämpning Utvärdera ett postfix uttryck Stack implementerad med en array Stack implementerad med en länkad lista ADT Stack Grundprinciper: En stack
Undantag. Engelska: exceptions. Skansholm: exceptionella händelser
Undantag Engelska: exceptions Skansholm: exceptionella händelser Fel som genereras om man försöker öppna en fil som inte finns, dividera med noll, indexera utanför en array osv. bjectorienterad programmering
Felhantering. Andra brott mot språkets regler. Man kan också i programmet bryta mot ett antal olika regler som gäller. Exempelvis:
Felhantering I de flesta program finns eller uppstår ett antal olika fel. Man behöver en strategi för att hitta och rätta till sådana fel. Olika typer av fel som kan inträffa: syntaktiska fel Olika form
Dagens program. Programmeringsteknik och Matlab. Objektorienterad programmering. Vad är vitsen med att ha både metoder och data i objekten?
Programmeringsteknik och Matlab Övning 4 Dagens program Övningsgrupp 2 (Sal Q22/E32) Johannes Hjorth hjorth@nada.kth.se Rum 4538 på plan 5 i D-huset 08-790 69 02 Kurshemsida: http://www.nada.kth.se/kurser/kth/2d1312
Tentamen ID1004 Objektorienterad programmering May 29, 2012
Omtentamen för ID1004 Objektorienterad programmering HT11, 29 maj 2012, 09-13 Denna tentamen examinerar 3 högskolepoäng av kursen. Inga hjälpmedel är tillåtna. Tentamen består av 12 frågor. Varje fråga
TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Erik Nilsson, Institutionen för Datavetenskap, LiU
TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Erik Nilsson, Institutionen för Datavetenskap, LiU På denna föreläsning: Interface Generiska klasser Undantag
F2 Datatyper och variabler. ID1004 Objektorienterad programmering Fredrik Kilander
F2 Datatyper och variabler ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Datatyper Java är ett starkt typat språk Varje slags data har en datatyp Datatyp Javasyntax Exempel Teckensträng
Övning2. Variabler. Data typer
Vahid 28 okt 2002 prgk02 Övning2 -Repetition -Variabler -Primitiva typer (+ boolean) -Operatörer +, ++, --, -Typ konvertering -Wrapper klasser -Jämförelse operatörer,(==, =, ,!=,!) -String hur man
Objektorienterad Programmering (TDDC77)
Objektorienterad Programmering (TDDC77) Föreläsning II: utmatning, variabler, typer Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2016 Kompilera och köra programmet under terminal 2: I Skapa Hej.java
Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper
Tentamen Programmeringsteknik I 2018-03-16 Skrivtid: 8:00 13:00 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer
Objektorienterad programmering. Fält som funktionsresultat. Mer om fält: att uppdatera ett parameterfält. Kontrast: Parametrar av primitiv typ
orienterad programmering Föreläsning 3 Exempel: Telefonboken Fält som funktionsresultat Exempel Definiera static double[] vectorsum(double[] a, double[] b) Betrakta sedan följande kodavsnitt:... double[]
Objektorienterad Programkonstruktion. Föreläsning 4 8 nov 2016
Objektorienterad Programkonstruktion Föreläsning 4 8 nov 2016 Nästade klasser I Java går det att deklarera en klass inuti en annan klass. Vi kallar detta för att en yttre klass innehåller en inre klass.
Föreläsning 2, vecka 8: Repetition
TDA 548: Grundläggande Programvaruutveckling Föreläsning 2, vecka 8: Repetition Magnus Myréen Chalmers, läsperiod 1, 2016-2017 Idag Metoder och terminologi Referensvärden och arrays Interface och ritning
Föreläsning 8 - del 2: Objektorienterad programmering - avancerat
Föreläsning 8 - del 2: Objektorienterad programmering - avancerat Johan Falkenjack johan.falkenjack@liu.se Linköpings universitet Sweden December 4, 2013 1 Innehåll Arv och andra viktiga begrepp Abstrakta
Objektorienterad Programmering DAT043. Föreläsning 4 23/1-18 Moa Johansson (delvis baserat på Fredrik Lindblads material)
Objektorienterad Programmering DAT043 Föreläsning 4 23/1-18 Moa Johansson (delvis baserat på Fredrik Lindblads material) 1 Repetion: Klasser och objekt Vi definierar nya objekttyper i klasser. Ett objekt
Objekt som argument. Föreläsning 7-8 Innehåll. Hur komma åt den andra kvadratens attribut? Anropa metod på objektet självt
Föreläsning 7-8 Innehåll Objekt som argument Antag att vi har lagt till följande metod i klassen Square (från lab 4). Mer om att skriva egna klasser Fel och felsökning Klasserna String och StringBuilder
Objekt och klasser - Introduktion
Objekt och klasser - Introduktion Begreppet objekt Hur klasser används för att skapa objekt Fördefinierade klasser Metoder och parameteröverföring Definiera klasser Modifierare Statiska variabler och metoder
TDDD78 Viktiga begrepp, del 2
jonas.kvarnstrom@liu.se 2015 TDDD78 Viktiga begrepp, del 2 Identitet och likhet Är likhet och identitet samma sak? Oj, vi har samma kläder på oss idag! Nej, men likadana! Besserwisser 3 Detta är två rutor
I STONE. I Variabler, datatyper, typkonvertering. I Logiska och matematiska uttryck. I Metoder-returvärde och parametrar. I Villkorssatser if/else
Förkunskaper från tidigare föreläsningar: Objektorienterad Programmering (TDDC77) Föreläsning IX: Klasser och Objekt, Instantiering Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2015 I STONE I Variabler,
F4 Klasser och Metoder. ID1004 Objektorienterad programmering Fredrik Kilander
F4 Klasser och Metoder ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Klasser och objekt Klasser definierar (utgör idén) Objekt instantierar (utgör förekomsten) En klassdefinition Många
I Skapa Hej.java och skriv programmet. I Kompilera med javac Hej.java. I Rätta fel och repetera tills du lyckas kompilera ditt program
Kompilera och köra programmet Objektorienterad Programmering (TDDC77) Föreläsning II: utmatning, variabler, typer Ahmed Rezine IDA, Linköpings Universitet Hösttermin 2016 under terminal 2: I Skapa Hej.java
Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper
Tentamen Programmeringsteknik I 2016-03-17 Skrivtid: 1400 1900 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer
Konstruktion av klasser med klasser
Konstruktion av klasser med klasser Klasser kan byggas på redan denierade klasser genom att klassobjekt används som dataattribut när en ny klass beskrivs. Exempel: Klassen PairOfDice har två attribut attribut
Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper
Tentamen Programmeringsteknik I 2016-06-11 Skrivtid: 0900 1400 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer
Dagens text. Programmeringsteknik. Mer om Scanner-klassen. Dialogrutor (klassen JOptionPane) Bubbelsortering. Omslagsklasser.
(1 oktober 2017 F5 1 ) Dagens text Programmeringsteknik Mer om Scanner-klassen Dialogrutor (klassen JOptionPane) Bubbelsortering ArrayList Omslagsklasser Arbetsexempel (1 oktober 2017 F5 2 ) Pokertärningar
Språkkonventioner och redigering av tal.
Språkkonventioner och redigering av tal. Kap J3-1 Konventioner för olika språk hanteras med hjälp av klassen java.util.locale Ett objekt i denna klass beskriver en lokal konvention. Lokala konventioner
Föreläsning 5&6 LOGISKA VARIABLER; IMPLEMENTERA KLASSER; MER ALGORITMER
Föreläsning 5&6 LOGISKA VARIABLER; IMPLEMENTERA KLASSER; MER ALGORITMER Logiska uttryck datatypen boolean Logiska uttryck kan ha två möjliga värden, true eller false. Variabler av typen boolean kan tilldelas
Del A (obligatorisk för alla)
Del A (obligatorisk för alla) A1. Ringa in rätt svarsalternativ eller skriv svar i ruta om sådan a) Satsen double x = (int)(1 + 3/2.0) + 3.; resulterar i b) Satsen int x = (int)(1 + 3/2.0) + 3.; resulterar
FÖRSLAG TILL LÖSNINGAR FÖR TENTAMEN I INTERNETPROGRAMMERING MED JAVA, 5p för SY , kl
Högskolan Dalarna sid 1 av 6 DI-institutionen Hans-Edy Mårtensson Sten Sundin FÖRSLAG TILL LÖSNINGAR FÖR TENTAMEN I INTERNETPROGRAMMERING MED JAVA, 5p för SY2 2001-03-16, kl 14.00-18.00 1. Grunderna i
Föreläsning 7-8 Innehåll
Föreläsning 7-8 Innehåll Mer om att skriva egna klasser Fel och felsökning Klasserna String och StringBuilder Datavetenskap (LTH) Föreläsning 7-8 HT 2017 1 / 42 Objekt som argument Antag att vi har lagt
Omtentamen för TDA540 Objektorienterad Programmering. Institutionen för Datavetenskap CTH HT-17, TDA540. Dag: , Tid:
Omtentamen för TDA540 Objektorienterad Programmering Institutionen för Datavetenskap CTH HT-17, TDA540 Dag: 2018-08-30, Tid: 14.00-18.00 Ansvarig: Examinator: Alex Gerdes Carlo A. Furia Förfrågningar:
Anmälningskod: Lägg uppgifterna i ordning. Skriv uppgiftsnummer (gäller B-delen) och din kod överst i högra hörnet på alla papper
Tentamen Programmeringsteknik I 2016-06-11 Skrivtid: 0900 1400 Tänk på följande Skriv läsligt. Använd inte rödpenna. Skriv bara på framsidan av varje papper. Lägg uppgifterna i ordning. Skriv uppgiftsnummer
Kopiering av objekt i Java
1 (6) Kopiering av objekt i Java Först När du läser detta papper bör du samtidigt studera dokumentationen för klasserna Object, Cloneable (java.lang) och ArrayList (java.util). Mycket blir klarare genom
TENTAMEN PROGRAMMERINGSMETODIK MOMENT 2 - JAVA, 4P
UME UNIVERSITET Datavetenskap 981212 TENTAMEN PROGRAMMERINGSMETODIK MOMENT 2 - JAVA, 4P Datum : 981212 Tid : 9-15 HjŠlpmedel : Inga Antal uppgifter : 9 TotalpoŠng : 60 (halva pošngtalet kršvs normalt fšr
Lösningsförslag, tentamen FYTA11 Javaprogrammering
Lunds universitet FYTA11 Institutionen för Astronomi och Teoretisk fysik HT 12 Lösningsförslag, tentamen FYTA11 Javaprogrammering Onsdag 9 januari 2013, 10:15 14:15 Instruktioner Hjälpmedel: Papper och
Testning och felhantering
Testning och felhantering Föreläsning 8 TDA540 - Objektorienterad Programmering Sammanfattning Textfiler Flerdimensionella fält ArrayList (dynamiska vs. statiska datastrukturer) Shorthand operatorer Testning
Föreläsning 8 SLUMPTAL, SIMULERING + INTRODUKTION TILL VEKTORER
Föreläsning 8 SLUMPTAL, SIMULERING + INTRODUKTION TILL VEKTORER Från laboration 3 till 4 I laboration 3 har du implementerat klasser implementerat metoder i klasserna I laboration 4 kommer du att implementera
Tentamen FYTA11 Javaprogrammering
Lunds universitet FYTA11 Institutionen för Astronomi och Teoretisk fysik HT 12 Tentamen FYTA11 Javaprogrammering Onsdag 9 januari 2013, 10:15 14:15 Instruktioner Hjälpmedel: Papper och penna. Behandla
TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU
TDDE10 m.fl. Objektorienterad programmering i Java Föreläsning 6 Erik Nilsson, Institutionen för Datavetenskap, LiU På denna föreläsning Generiska klasser Undantag Interface Nästlade klasser 1 Problem:
Skriftlig tentamen för kursen DV017A. Inledande programmering i Java A
Skriftlig tentamen för kursen DV017A Inledande programmering i Java A Skrivtid 4 timmar 09.00 13.00 Instruktioner Detta är en tentamen som består av fleralternativsfrågor. Här är några viktiga punkter: