TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 4
|
|
- Camilla Berg
- för 8 år sedan
- Visningar:
Transkript
1 TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 4 Pelle Evensen, Daniel Wetterbro 17 november 2009 Sammanfattning Denna vecka ska vi titta på designmönstren State och Decorator, mer om klassinvarianter samt trådar. Övningarna är graderade (något subjektivt) från lätt ( ) till svår ( ). Svårighetsgraden hos en övning har inte nödvändigtvis med lösningens storlek att göra. 1 State Den mycket kompetente hushållsassistenten Arnold har byggts och ska konfigureras till användning två dagar i veckan 1. För att lätt kunna ändra på konfigurationen ska designmönstret State användas; där olika sätt att utföra operationerna lätt kan bytas ut genom att sätta olika tillstånd (states). De olika tillstånden medför dessutom att varje beteende blir väldefinierat. Se klasserna Arnold, DefaultState samt SundayState, fig Man kör Arnold genom två metoder: setday() berättar för Arnold vilken veckodag det är. work() får Arnold att städa och laga mat, om han tycker att det är en bra dag för det... Det saknas två delar i implementation: Interfacet RobotState som beskriver ett tillstånd (implementeras av alla tillstånd). En klass som beskriver vad Arnold ska göra på onsdagar (alltså ytterligare ett tillstånd för Arnold). Skriv dessa! 1 Arnold kräver så pass mycket underhåll att kunder drar sig för mer frekvent användning. 1
2 * Arnold, a personal household assistant public class Arnold { private RobotState state = null; public enum Weekday { MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY public Arnold() { this.state = new DefaultState(); public void setday(weekday day) { switch (day) { case WEDNESDAY: System.out.println("\nWednesday acknowledged!"); this.state = new WednesdayState(); break; case SUNDAY: System.out.println("\nSunday acknowledged!"); this.state = new SundayState(); break; default: System.out.println("\nAah.. I love lazy days!"); this.state = new DefaultState(); break; public void work() { clean(); cook(); private void clean() { System.out.println("\nI need to clean?"); state.clean(); private void cook() { System.out.println("\nI need to cook?"); state.cook(); public static void main(string[ ] args) { Arnold mypersonalarnold = new Arnold(); mypersonalarnold.setday(weekday.monday); mypersonalarnold.work(); mypersonalarnold.setday(weekday.wednesday); mypersonalarnold.work(); mypersonalarnold.setday(weekday.sunday); mypersonalarnold.work(); Figur 1: Klassen Arnold. 2
3 public class DefaultState implements RobotState public void clean() { System.out.println("\nHa! In a free country " + "a free day is a free day!\n" + "Ahil bi public void cook() { System.out.println("\nHa! In a free country " + "a free day is a free day!\n" + "Ahil bi back!"); Figur 2: Klassen DefaultState. public class SundayState implements RobotState public void clean() { try { System.out.println("\nTerminating your trash!"); Thread.sleep(1000); System.out.println("Killing rats..."); Thread.sleep(1000); System.out.println("Using vacuum cleaner..."); Thread.sleep(1000); System.out.println("Wiping floor..."); catch (InterruptedException ie) { public void cook() { try { System.out.println("\nYou live to eat and eat to live!"); Thread.sleep(1000); System.out.println("Shooting bull..."); Thread.sleep(1000); System.out.println("Cutting meat..."); Thread.sleep(1000); System.out.println("Desinfecting hands..."); Thread.sleep(1000); System.out.println("Marinading meat..."); Thread.sleep(1000); System.out.println("Preparing salad..."); Thread.sleep(1000); System.out.println("Setting table..."); Thread.sleep(1000); System.out.println("Shouting..."); Thread.sleep(1000); System.out.println("Serving..."); catch (InterruptedException ie) { Thread.currentThread().interrupt(); Figur 3: Klassen SundayState. 3
4 2 Decorator Olika utbildningar kräver olika kvalifikationer. Många har dessutom samma typ av krav, men i olika kombinationer. För att dela upp behandlingen av de olika kriterierna skrivs de med fördel i olika klasser. Men om arv skulle användas för att kedja samman kriterier för olika bedömningar sker en explosion i antal klasser; om antal olika kriterier är n, blir antal olika bedömningar n i=1 i!. Istället kan designmönstret Decorator användas. Då kan en bedömning dynamiskt (under körning) dekoreras (utökas) med nya kriterier. I uppgiften ska Sven och Arne söka till två utbildningar, älgförsäljare respektive ett internship som ekonom med positionering i Frankfurt; båda kräver naturligtvis kunskaper i det tyska språket. Älgförsäljarjobbet kräver dessutom goda färdigheter i skytte medan ekonompositionen kräver ett visst resultat på högskoleprovet. Den ofullständiga implementationen finns i klasserna Application, CriterionDecorator, Mark och Criterion i fig Lägg till de tre kriterieklasserna: HpCriterion, ShootingCriterion och GermanCriterion. 4
5 * Application information public class Application { private String name; private double hppoints; private Mark germanmark; private Mark shootingmark; 0.0 <= hpp <= 2.0 hpp Högskoleprov result gm German language mark sm Shooting skill mark public Application(String n, double hpp, Mark gm, Mark sm) { this.name = n; this.hppoints = hpp; this.germanmark = gm; this.shootingmark = sm; /*... Accessor methods omitted... * Test program args ignored public static void main(string[ ] args) { // Create criteria Criterion mooseseller = new GermanCriterion(Mark.SUFFICIENT, new ShootingCriterion(Mark.EXCELLENT)); Criterion frankfurteconomist = new GermanCriterion(Mark.EXCELLENT, new HpCriterion(1.8)); // Create applications Application svenapp = new Application("Sven Svensson", 1.8, Mark.GOOD, Mark.EXCELLENT); Application arneapp = new Application("Arne Andersson", 1.7, Mark.EXCELLENT, Mark.SUFFICIENT); // Test applications against criteria System.out.println("Is Sven a possible moose seller?\n: " + mooseseller.evaluate(svenapp)); System.out.println("Is Arne a possible economist in Frankfurt?\n: " + frankfurteconomist.evaluate(arneapp)); Figur 4: Klassen Application. 5
6 * Decorator for criteria public abstract class CriterionDecorator implements Criterion { private Criterion nextcriterion; c A possible next criterion, null for termination of chain. public CriterionDecorator(Criterion c) { nextcriterion = public boolean evaluate(application a) { if (nextcriterion!= null) { return nextcriterion.evaluate(a); else { return true; Figur 5: Klassen CriterionDecorator. * Enumeration of mark levels public enum Mark { POOR, SUFFICIENT, GOOD, EXCELLENT Figur 6: Klassen Mark. * Criterion public interface Criterion { a is non-null a Application to evaluate true if the evaluation passed, false otherwise. public boolean evaluate(application a); Figur 7: Klassen Criterion. 6
7 3 Trådar 3.1 Runnable och Thread Skriv klart klasserna ShoutTest, ShoutRunnable och ShoutThread (fig. 8 10). Låt varje aktör vila en sekund mellan sina skrik. Vilka fördelar respektive nackdelar finns det med Thread kontra Runnable? public class ShoutTest { public static void main(string[ ] args) { Thread pelle = new ShoutThread("Pelle", "Daniel"); Runnable daniel = new ShoutRunnable("Daniel", "Pelle"); // Add your own code to make Pelle start shouting at // Daniel and vice versa. Figur 8: Klassen ShoutTest. public class ShoutRunnable implements Runnable { private final String from; private final String to; public ShoutThread(String from, String to) { this.from = from; this.to = to; private void shout() { System.out.println(from + " shouts: Done with " + " the exercises yet, " + to + "???"); public class ShoutThread extends Thread { private final ShoutRunnable g; public ShoutThread(String from, String to) { g = new ShoutRunnable(from, to); // Add necessary methods here. Figur 10: Klassen ShoutThread. // Add necessary methods here. Figur 9: Klassen ShoutRunnable. 3.2 Time of check/time of use (TOCTOU) Ett ganska vanligt fel då man handskas med data som kan förändras av andra trådar eller processer är att man utgår från att data fortfarande har samma värde då man använder dem som när man senast läste av dem. Detta fel är allmänt känt som Time of check/time of use. Problemet kan alltså uppstå då det finns en möjlig tidsavvikelse mellan check och use. Kan problemet uppstå för icke-muterbara klasser? 7
8 3.2.1 TOCTOU I Med texten ovan som ledning, förklara hur vi kan bryta mot klassinvarianten i Period (fig. 11). Denna klass såg vi i vecka två. De problem vi hade då löste vi med hjälp av defensiv in- och utkopiering. Klassen är efter denna åtgärd dock fortfarande inte trådsäker. Hur kan vi lösa problemet (garantera att klassinvarianten alltid håller)? getstart() is before or at the same time as getend() public final class Period { private final Date start; private final Date end; start the beginning of the period end the end of the period; must not precede start start.compareto(end) <= 0 IllegalArgumentException if start is after end NullPointerException if start or end is null public Period(Date start, Date end) { if (start.compareto(end) > 0) { throw new IllegalArgumentException(start + " after " + end); this.start = new Date(start.getTime()); this.end = new Date(end.getTime()); public Date getstart() { return new Date(start.getTime()); public Date getend() { return new Date(end.getTime()); Figur 11: Klassen Period. 8
9 3.2.2 Ofullständig klassinvariant & race conditions Ett race condition är en defekt i ett program vilket gör att programmet bara fungerar korrekt när saker sker i en viss (oväntat välbestämd) ordning. Klassen LightColor (fig. 12) vill vi kunna använda för att garantera att vi bara kan få tag på ljusa Color-objekt. Kriteriet för ljus är att medelvärdet av intensitetsvärdena för röd, grön & blå är över 128. Följande deluppgifter visar på varför denna specifikation är otillräcklig; 1. Det saknas en klassinvariant om man vill kunna garantera att ascolor alltid returnerar ett giltigt Color-objekt. Fundera ut hur en lämplig komplettering av den befintliga invarianten skulle kunna se ut och lägg till eventuell kod i checkinvariant. Ledtråd: Fundera ut vad lämpligt pre för metoden ascolor skulle kunna vara. Bör metoden under några omständigheter kasta exception? 2. Vad bör pre och post vara för metoden setcolor? Använd följande notation: x är parametern x och after.x är instans-/klassvariabeln x:s tillstånd då metoden returnerar. 3. Visa varför man fortfarande inte är garanterad att ascolor returnerar en ljus färg, om än ett giltigt Color-objekt. Tänk på att flera trådar kan dela på samma LightColor-objekt. Det finns alltså ett race condition i koden. 4. Lägg till lämplig kod som gör att båda invarianterna håller samt garanterar att man alltid får tillbaka en ljus färg av ascolor. 9
10 r + g + b > THRESHOLD Think of one more reasonable invariant... public class LightColor { public static final THRESHOLD = 384; private int r, g, b; IllegalArgumentException if the colour specified by r, g, b is too dark. public LightColor(int r, int g, int b) { setcolor(r, g, b); What should the precondition(s) be? What should the postcondition(s) be? IllegalArgumentException if the colour specified by r, g, b is too dark. public setcolor(int r, int g, int b) { if(checkinvariant(r, g, b)) { this.r = r; this.g = g; this.b = b; else { throw new IllegalArgumentException( "The sum of r, g, b must be greater than " + THRESHOLD); // See setcolor(int, int, int) public setcolor(color c) { setcolor(c.getred(), c.getgreen(), c.getblue()); * Returns a Color-view of this object. What should the precondition(s) be? Can this method throw? public Color ascolor() { return new Color(r, g, b); // Make sure that the the rgb triple will satisfy the invariant. private boolean checkinvariant(int r, int g, int b) { return r + g + b > THRESHOLD; Figur 12: Klassen LightColor. 10
11 3.3 Deadlock Betrakta klassen Person 2 (fig. 13). Här sitter Daniel och Pelle och tänker. Det är dock inte helt lyckat att de kan störa varandra när som helst. Gör så att en person inte får bli störd medans den tänker. Det vill säga, om en annan tråd anropar getaquestionfrom så får den andra tråden vänta tills den första tråden låtit personen tänka klart. Om man synkroniserar alla metoder, blir programmet trådsäkert? Antag t.ex. att man låter både getaquestion och getananswer vara synchronized. public class Person extends Thread { private String name; private Person whomtoask; public Person(String name) { this.name = name; public void setwhomtoask(person whomtoask) { this.whomtoask = whomtoask; public String tostring() { return name; private void getaquestionfrom(person p) { try { System.out.println(this + " says: I got a question from " + p); // Think a while before answering... Thread.sleep(50); p.getananswerfrom(this); catch (InterruptedException e) { Thread.currentThread().interrupt(); private void getananswerfrom(person p) { System.out.println(this + " says: I got an answer from " + p); public void run() { whomtoask.getaquestionfrom(this); public static void main(string[ ] args) { Person p1 = new Person("Pelle"); p1.setwhomtoask(p2); Person p2 = new Person("Daniel"); p2.setwhomtoask(p1); p1.start(); p2.start(); Figur 13: Klassen Person. 2 Lånad av Bror Bjerner från tentamen april
12 3.3.1 Om svårigheten att testa program. Om man har n personer, hur lång tid tar det ungefär innan eventuella fel ovan manifesterar sig (vi ser effekten av dem) givet antaganden nedan; Antag att man har många personer i systemet. Alla personer ställer en fråga var tionde sekund eller så till en slumpvis vald (annan) person. De ligger inte nödvändigtvis i fas med varandra även om de ställer frågorna med någorlunda regelbundenhet. Varje person tar 1 ms på sig att svara och ställa en motfråga. Antag att vi gör hela getaquestion() och getananswer() synchronized. Får man samma resultat (fast snabbare eller långsammare) om man ändrar ordningen så här; Antag att ordningen är strikt cyklisk så att varje person k först ställer sin fråga till person mod(k + 1, n), sedan väntar en stund, frågar person mod(k + 2, n), o.s.v. 3. Antag också att de vid från början (men kanske inte senare) är i fas med varandra. Som deluppgift betraktad så är denna väl svår (och kanske inte tillräckligt välspecificerad) för att man ska kunna utföra en bra beräkning. Tänkvärt är dock om sannolikheten att det blir trassel/lösningen inte fungerar som tänkt är noll eller inte. [Blo08] Referenser [Blo08] Joshua Bloch. Effective Java. Addison-Wesley, 2nd edition, mod(a, b) är restdivision för a. Synonymt med a % b i Java. b 12
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 2
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 2 Pelle Evensen, Daniel Wetterbro 5 november 2009 Sammanfattning Denna vecka ska vi titta på abstrakta klasser kontra interface,
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 3
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 3 Pelle Evensen, Daniel Wetterbro 16 oktober 2012 Sammanfattning Denna vecka ska vi titta på polymorfism, dynamisk kontra statisk
Läs merÖvning 4. I denna övning ska vi titta på icke-muterbarhet kontra muterbarhet, samt metoderna equals, hashcode och clone.
TDA550 - Objektorienterad programvaruutveckling, fk Övning 4. I denna övning ska vi titta på icke-muterbarhet kontra muterbarhet, samt metoderna equals, hashcode och clone. Uppgift 1 Icke-muterbarhet kontra
Läs merConcurrency Saker händer samtidigt. Process En instans av ett program
Concurrency Saker händer samtidigt Hur gör vi flera saker samtidigt på en dator? - Dela på en CPU - Flera CPU Flera processer på en dator. Operativsystemet (OS) tilldelar dem körtid (time slices, prioritet)
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 5
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 5 Daniel Wetterbro 23 november 2009 Sammanfattning Denna vecka ska vi titta på I/O, samlingar och generics. Övningarna är graderade
Läs merTentamen Programmering fortsättningskurs DIT950
Tentamen Programmering fortsättningskurs Datum: 2015-03-17 Tid: 08.30-12.30 Hjälpmedel: Engelskt-Valfritt språk lexikon Betygsgränser: U: -23 G: 24-43 VG: 44-60 (max 60) Lärare:. Någon besöker ca 10.00
Läs merÖvning vecka 4. Denna vecka ska vi titta på icke-muterbarhet kontra muterbarhet, samt metoderna equals, hashcode och clone.
TDA550 - Objektorienterad programvaruutveckling IT, fk Övning vecka 4. Denna vecka ska vi titta på icke-muterbarhet kontra muterbarhet, samt metoderna equals, hashcode och clone. Uppgift 1 Icke-muterbarhet
Läs mer/* * * Lösningsförslag tentamen DIT950 * Datum * */ /* * -1 - */ För samtliga gäller,se föreläsningsanteckningar.
* * Lösningsförslag tentamen DIT950 * Datum 150317 * * -1 - För samtliga gäller,se föreläsningsanteckningar. * - 2 - (Diagram visas inte, kontakta mig för ev frågor) // a C c = new A(); // Compile! Sub
Läs mer1.1 Runnable och Thread
1 Trådar 1.1 Runnable och Thread I övningen är ShoutThread hårdkodad att använda just ShoutRunnable. Det typiska förfarandet brukar annars vara att skicka över din Runnable i konstruktor-anropet till Thread:
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 5
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 5 Pelle Evensen & Daniel Wetterbro 20 oktober 2011 Sammanfattning Denna vecka ska vi titta på samlingar, generics och designmönstren
Läs merLö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,
Läs merRepetition av OOP- och Javabegrepp
ArrayList Repetition av OOP- och Javabegrepp En lista i vilken man kan lagra objekt Implementerar List-interfacet Skiljer sig från ett vanligt endimensionellt fält: Dynamisk expanderar när den blir
Läs merRepetition av OOP- och Javabegrepp
ArrayList Repetition av OOP- och Javabegrepp En lista i vilken man kan lagra objekt Implementerar List-interfacet Skiljer sig från ett vanligt endimensionellt fält: Dynamisk expanderar när den blir
Läs merKungliga Tekniska Högskolan Ämneskod 2D4134 Nada Tentamensdag 2001 - maj - 19 Tentamen i Objektorientering och Java Skrivtid 5 h
Kungliga Tekniska Högskolan Ämneskod 2D4134 Nada Tentamensdag 2001 - maj - 19 Tentamen i Objektorientering och Java Skrivtid 5 h Antalet uppgifter : 2 (20p + 20p = 40 p) ) Lärare, jourhavande lärare :
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 1
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 1 Pelle Evensen, Daniel Wetterbro 28 oktober 2009 Sammanfattning Denna vecka ska vi titta på skillnader mellan primitiva typer
Läs merTentamen LÖSNINGSFÖRSLAG. c) Tilldelningen C x = new D() ger kompileringsfel eftersom klassen D är abstrakt.
Tentamen 101213 - LÖSNINGSFÖRSLAG Uppgift 1. a) Ger utskriften c( ) in D b) Ger utskriften true c) Tilldelningen C x = new D() ger kompileringsfel eftersom klassen D är abstrakt. d) Ger utskriften b( )
Läs merLösningsförslag. Programmeringsmetodik, KV: Java och OOP. 17 januari 2004
Lösningsförslag Programmeringsmetodik, KV: Java och OOP 17 januari 2004 Examinator: Johan Karlsson Skrivtid: 9-15 Hjälpmedel: En av följande böcker: Barnes & Kölling: Objects First With Java a practical
Läs merFö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
Läs merFö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 Evaluate postfix expressions Läsanvisningar
Läs merParallellism, å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
Läs merÖvning vecka 6. public void method2() { //code block C method3(); //code block D }//method2
Övning vecka 6. TDA550 - Objektorienterad programvaruutveckling IT, fk Denna vecka ska vi titta på undantag, testning, generiska enheter, samlingar och designmönstret Iterator. Uppgift 1 Exceptions a)
Läs merÖvning 5. TDA550 - Objektorienterad programvaruutveckling, fk
TDA550 - Objektorienterad programvaruutveckling, fk Övning 5. Denna vecka ska vi titta på designmönstren Singleton, State, Observer, Composite och Decorator, samt gränssnittet Comparator. Uppgift 1 Syftet
Läs merObjektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Jonas Lindgren, Institutionen för Datavetenskap, LiU
TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 4 Jonas Lindgren, Institutionen för Datavetenskap, LiU På denna föreläsning: Interface Generiska klasser Undantag
Läs merTDDC30. 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
Läs merObjektorienterad programvaruutveckling, fk, TDA550. Exempeltentamen
Objektorienterad programvaruutveckling, fk, TDA550 Exempeltentamen Uppgift 1. a) Vad skriver programmet ut? Motivera! public class A { public void f() { System.out.println("A.f"); public void h() { f();
Läs merTentamen Programmeringsteknik II Inledning. Anmälningskod:
Tentamen Programmeringsteknik II 2016-01-11 Inledning I bilagan finns ett antal mer eller mindre ofullständiga klasser. Några ingår i en hierarki: List, SortedList, SplayList och ListSet enligt vidstående
Läs merIdag. 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
Läs merOutline. 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
Läs merObjektorienterad 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
Läs merChapter 4: Writing Classes/ Att skriva egna klasser.
Chapter 4: Writing Classes/ Att skriva egna klasser. I dessa uppgifter kommer du att lära dig om hur man definierar egna objekt genom att skriva klasser. Detta är grunden för att förstå objekt orienterad
Läs merObjektorienterad 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
Läs merVad kännetecknar en god klass. Vad kännetecknar en god klass. F12 Nested & Inner Classes
Vad kännetecknar en god klass F12 Nested & En odelad, väldefinierad abstraktion Uppgiften kan beskrivas kort och tydlig Namnet är en substantiv eller adjektiv som beskriver abstraktionen på ett adekvat
Läs merFöreläsning 4. ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista
Föreläsning 4 Kö Föreläsning 4 ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista ADT Kö Grundprinciper: En kö fungerar som en kö. Man fyller på den längst bak och
Läs merObjektorienterad Programkonstruktion. Föreläsning 2 2 nov 2016
Objektorienterad Programkonstruktion Föreläsning 2 2 nov 2016 Objekt - klass Namn Fält1 Fält2 Fält3 Metod1 Metod2 Metod3 Metod4 Objekt - klass Objekt - klass Objekt - klass + Objekt - klass public class
Läs merOmtentamen 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:
Läs merDetta dokument är ett exempel, cirka hälften av en tentamen för TDA545 Objektorienterad programvaruutveckling
Göteborg, Magnus Myréen, 2014-10- 15 Detta dokument är ett exempel, cirka hälften av en tentamen för TDA545 Objektorienterad programvaruutveckling Fulltentamen vitsord: 3=28p, 4=38p, 5= 48p, max 60p. Max
Läs merFö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
Läs merTDDE10 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
Läs merJavas Exceptions. DD2385 Programutvecklingsteknik Fler bilder till föreläsning 7 23/ Kort om Javas Exceptions Trådar i Java
DD2385 Programutvecklingsteknik Fler bilder till föreläsning 7 23/4 2014 Innehåll Kort om Javas Exceptions Trådar i Java swing- klassen Timer Klient-Server-program Javas Exceptions Checked måste hanteras,
Läs merObjektorienterad programutveckling, fk
till tentamen P r e l i m i n ä r 1 (6) Kurs Objektorienterad programutveckling, fk Program DAI2 Läsår 2017/2018, lp 2 Examinator Uno Holmer Uppgift 1 (7 p) Metoden i tesen bryter mot designprincipen separation
Läs merProgrammering 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
Läs merFö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
Läs merKompilering 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
Läs merSI-pass 4. Johan Brook och Jesper Persson. 25 september 2012. Diskutera och svara på om påståendena nedan är äkta sanningar eller listiga lögner.
SI-pass 4 Johan Brook och Jesper Persson 25 september 2012 1. Sant eller falskt? Diskutera och svara på om påståendena nedan är äkta sanningar eller listiga lögner. Interfaces i Java kan innehålla privata
Läs merTentamen för TTIT71 Programmering 2007-01-10 kl. 08-12 Institutionen för datavetenskap Linköpings universitet. Uppgift 1. (2 p)
Tentamen för TTIT71 Programmering 2007-01-10 kl. 08-12 Institutionen för datavetenskap Linköpings universitet Antal uppgifter: 6 Max: 32 poäng Betyg: 3:a 16 poäng, 4:a 24 poäng, 5:a 28 poäng Hjälpmedel:
Läs merLite 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
Läs merTentamen. 2D4135 vt 2005 Objektorienterad programmering, design och analys med Java Lördagen den 28 maj 2005 kl 9.00 14.
Tentamen 2D4135 vt 2005 Objektorienterad programmering, design och analys med Java Lördagen den 28 maj 2005 kl 9.00 14.00, sal E33 Tentan har en teoridel och en problemdel. På teoridelen är inga hjälpmedel
Läs merThe Last Adventure. Innehåll. Objektorientering. Språket Java. Java - Paket. Java - synlighet. Den sista lektionen. Repetition.
Innehåll The Last Adventure Den sista lektionen Repetition Examination Slutar 14:45 (minnesstund) Många saker "flashar" förbi - hojta Objektorientering Språket Java Class Object Inheritance Polymorphism
Läs merDI-institutionen Sid 1 av 6 Hans-Edy Mårtensson Sten Sundin
DI-institutionen Sid 1 av 6 Hans-Edy Mårtensson Sten Sundin TENTAMEN I IKB007 INTERNETPROGRAMMERING MED JAVA för SY2 1999-03-17, kl 14.00-18.00 Hjälpmedel: En lärobok i Java programmering Återlämningstillfälle:
Läs merJAVAUTVECKLING LEKTION 4
JAVAUTVECKLING LEKTION 4 2016 Mahmud Al Hakim mahmud.al.hakim@nackademin.se www.alhakim.se AGENDA Iterationer (loopar) Algoritmer Mer om felsökning 1 WHILE-SATSEN String s = JOptionPane.showInputDialog("Talet
Läs merSvaret kan ges i Javakod (eller i UML-klassdiagram). public class A { B minb;... } public class B { <B:s många variabler och metoder> } Lösning:
Lös koppling mellan programdelar (klasser) eftersträvas ofta i objektorienterad programmering. Om klassen A beror av klassen B, hur kan man lösa upp detta beroende och åstadkomma en lösare koppling mellan
Läs merFöreläsning 3: Booleans, if, switch
TDA 545: Objektorienterad programmering Föreläsning 3: Booleans, if, switch Magnus Myréen Chalmers, läsperiod 1, 2015-2016 Påminnelse om klasser och objekt Boll boll1 = new Boll(5,12); skapar ett nytt
Läs merLösningsförslag till tentamen i EDAF25 Objektorienterad modellering och design Helsingborg
LUNDS TEKNISKA HÖGSKOLA 1(7) Institutionen för datavetenskap Lösningsförslag till tentamen i EDAF25 Objektorienterad modellering och design Helsingborg 1. a) Figure 1 2015 06 04 GeometryApp GraphicalApp
Läs mer1 Comparator & Comparable
1 Comparator & Comparable 1.1 Implementation av Comparable Att implementera Comparable innebär att man gör objekt av sin klass jämförbara med andra och att det därmed antas existera en naturlig ordning
Läs merAtt 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
Läs merInstitutionen för TENTAMEN CTH VT-14 Datavetenskap 2014-04-22 TDA550 DAG: 14-04-22 TID: 8:30 12:30
Institutionen för TENTAMEN CTH VT-14 Datavetenskap 2014-04-22 TDA550 Tentamen för TDA550 Objektorienterad programvaruutveckling IT, fk DAG: 14-04-22 TID: 8:30 12:30 Ansvarig: Christer Carlsson, ankn 1038
Läs merLösningsförslag till tentamen i EDA011 Programmeringsteknik för F, E, I, π och N
Lösningsförslag till tentamen i EDA011 Programmeringsteknik för F, E, I, π och N Måndagen den 24 april 2006 Del 1 Uppgift 1 Klassen VotingResult innehåller förhoppningsvis inga större överraskningar, operationen
Läs merFöreläsning 8: Exempel och problemlösning
TDA 545: Objektorienterad programmering Föreläsning 8: Exempel och problemlösning Magnus Myréen Chalmers, läsperiod 1, 2015-2016 De tre senaste föreläsningarna Läsanvisning: kap 2 & 13 meddelanden och
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 4
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 4 Pelle Evensen 16 oktober 2012 Sammanfattning Denna vecka ska vi titta på gränssnitten Comparable och Comparator samt exceptions,
Läs merDUGGA: Objektorienterade applikationer. Läs detta! Uppgifterna är inte avsiktligt ordnade efter svårighetsgrad.
1 (8) DUGGA: Objektorienterade applikationer Läs detta! Uppgifterna är inte avsiktligt ordnade efter svårighetsgrad. Skriv ditt namn, personnummer och e-postadress på försättsbladet. Skriv rent dina svar.
Läs merE02 "The Review" Föreläsning 2, HT2013 Grunderna, repetition. Johan Leitet. Kurs: 1dv403 Webbteknik I
E02 "The Review" Föreläsning 2, HT2013 Grunderna, repetition Kurs: 1dv403 Webbteknik I Johan Leitet E02 - "The Review" Dagens agenda Identifierare Kommentarer Variabler Datatyper Operatorer Villkorssatser
Läs merLösningsförslag till tentamen FYTA11 Javaprogrammering
Lunds universitet FYTA11 Institutionen för Teoretisk Fysik HT 08 Lösningsförslag till tentamen FYTA11 Javaprogrammering Fredag 9:e januari 2009, 09:00 13:00 Uppgift 1: Leta buggar Titta på klasserna A,
Läs merFakulteten för ekonomi, kommunikation och IT. Corba. Datum: Mathias Andersson
Fakulteten för ekonomi, kommunikation och IT Corba Datum: 2007-10-17 Namn: Kurs: Henrik Bäck Mathias Andersson DVGC02 Innehållsförteckning Implementation 3 IDL-fil 3 Server 3 Klient 3 Körning 3 Bilagor
Läs merTENTAMEN 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
Läs merFöreläsning 4. ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista Läsanvisningar och uppgifter
Föreläsning 4 Kö Föreläsning 4 ADT Kö Kö JCF Kö implementerad med en cirkulär array Kö implementerad med en länkad lista Läsanvisningar och uppgifter ADT Kö Grundprinciper: En kö fungerar som en kö. Man
Läs merLösningsförslag till tentamen
till tentamen 1 (6) Kurs Objektorienterad programmering Program D2 Läsår 2010/2011, lp 1 Examinator Uno Holmer Uppgift 1 (10 p) Ingen lösning ges. Se kurslitteraturen. Uppgift 2 (11 p) public class CounterButton
Läs merDetta dokument är ett exempel, cirka andra hälften av en tentamen för TDA545 Objektorienterad programvaruutveckling
Detta dokument är ett exempel, cirka andra hälften av en tentamen för TDA545 Objektorienterad programvaruutveckling Fulltentamen vitsord: 3=28p, 4=38p, 5= 48p, max 60p. Max 30p i denna halvtentamen Hjälpmedel:
Läs merInstitutionen för TENTAMEN CTH HT-17 Datavetenskap TDA550
Institutionen för TENTAMEN CTH HT-17 Datavetenskap 2017-01-13 TDA550 Tentamen för TDA550 Objektorienterad programvaruutveckling, fk DAG: 17-01-13 TID: 14:00 18:00 Ansvarig: Christer Carlsson, ankn 1038
Läs merTDDC30. Kursledning Kursledare: Jonas Lindgren. Labassistent: Jonas Lindgren Labassistent: Niklas Holma Labassistent: Erik Nilsson
TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 1 Jonas Lindgren, Institutionen för Datavetenskap, LiU På denna föreläsning: Kursinformation Imperativa delen av
Läs merExamination i. PROGRAMMERINGSTEKNIK F1/TM1 TIN212 (Dugga) Dag: Onsdag Datum: 2014-12-17 Tid: 9.00-12.00 (OBS 3 tim) Rum: V
Data och Informationsteknik / Computer Science and Engineering Chalmers University of Technology and University of Gothenburg Erland Holmström Göteborg 16 dec 2014 Examination i PROGRAMMERINGSTEKNIK F1/TM1
Läs merTentamen Nätverksprogrammering Lösningsförslag
LUNDS TEKNISKA HÖGSKOLA 1(6) Institutionen för datavetenskap Tentamen Nätverksprogrammering Lösningsförslag 2012 05 28, 8.00 13.00 Del 1 1. Time To Live (TTL) anger hur många routrar ett multicastpaket
Läs merTentamen Programmeringsteknik II Skrivtid: Hjälpmedel: Java-bok (vilken som helst) Skriv läsligt! Använd inte rödpenna!
Tentamen Programmeringsteknik II 2014-01-09 Skrivtid: 0800-1300 Hjälpmedel: Java-bok (vilken som helst) Tänk på följande Skriv läsligt! Använd inte rödpenna! Skriv bara på framsidan av varje papper. Börja
Läs merRecitation 4. 2-D arrays. Exceptions
Recitation 4. 2-D arrays. Exceptions Animal[] v= new Animal[3]; 2 declaration of array v Create array of 3 elements v null a6 Assign value of new-exp to v Assign and refer to elements as usual: v[0]= new
Läs merTung bakgrundsaktivitet t.ex. Aktiva objekt t.ex. Animering, simulering. DD2385 Programutvecklingsteknik Några bilder till föreläsning 9 6/5 2013
DD2385 Programutvecklingsteknik Några bilder till föreläsning 9 6/5 2013 Innehåll Trådar i Java swing- klassen Timer Klient-Server-program Trådar Tråd = enkel process Ett program kan ha flera trådar, flera
Läs merInstitutionen för TENTAMEN CTH VT-15 Datavetenskap 2015-04-13 TDA550 DAG: 15-04-13 TID: 8:30 12:30
Institutionen för TENTAMEN CTH VT-15 Datavetenskap 2015-04-13 TDA550 Tentamen för TDA550 Objektorienterad programvaruutveckling IT, fk DAG: 15-04-13 TID: 8:30 12:30 Ansvarig: Christer Carlsson, ankn 1038
Läs merFöreläsning 12: Exempel och problemlösning
TDA 545: Objektorienterad programmering Föreläsning 12: Exempel och problemlösning Magnus Myréen Chalmers, läsperiod 1, 2015-2016 Idag Problemlösning, dvs hur man ska tänka för att hitta lösning int mängd/set
Läs merObjektorienterad 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
Läs merF4. 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
Läs merDAT043 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
Läs merTentamen, EDAA20/EDA501 Programmering
LUNDS TEKNISKA HÖGSKOLA 1(4) Institutionen för datavetenskap Tentamen, EDAA20/EDA501 Programmering 2011 10 19, 8.00 13.00 Anvisningar: Denna tentamen består av fem uppgifter. Preliminärt ger uppgifterna
Läs merOOP 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
Läs merLö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-15, TDA540 Dag: 2016-04-09, Tid: 14.00-18.00 Uppgift 1 Metoden mystery vänder om ett fält.
Läs merTentamen. Lösningsförslag
Sida 1/8 Tentamen Grundläggande programmering i Java A 5p, DTAA32 2002-03-22 Lösningsförslag Uppgift 1 ( 3p ) Utskriften blir: Skriv in ett tal 24 47 48 intal=471 Uppgift 2 ( 6p ) a.) b.) c.) d.) e.) falskt
Läs merOmtentamen 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-04-06, Tid: 14.00-18.00 Ansvarig: Examinator: Alex Gerdes Carlo A. Furia Förfrågningar:
Läs merTDDE10 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:
Läs merInstitutionen för TENTAMEN CTH VT-15 Datavetenskap 2015-08-19 TDA550 DAG: 15-08-19 TID: 8:30 12:30
Institutionen för TENTAMEN CTH VT-15 Datavetenskap 2015-08-19 TDA550 Tentamen för TDA550 Objektorienterad programvaruutveckling IT, fk DAG: 15-08-19 TID: 8:30 12:30 Ansvarig: Christer Carlsson, ankn 1038
Läs merModelsvar för Tentamen för Objektorienterad programvaruutveckling, TDA545
Data och Informationsteknik / Computer Science and Engineering Chalmers University of Technology and University of Gothenburg Magnus Myréen Modelsvar för Tentamen för Objektorienterad programvaruutveckling,
Läs merLösningar till tentamen i EDAF25
Lösningar till tentamen i EDAF25 1 juni 2017 Lösning 1 Se figur 1. Figure 1: Tillståndsdiagram espressomaskin Lösning 2 (a) Kompositmönstret (b) Se figur 2 (c) Se figur 3 : Square : Drawing : Group : Circle
Läs merTentamen 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
Läs merInstitutionen för TENTAMEN CTH HT-14 Datavetenskap 2015-01-14 TDA550 DAG: 15-01-14 TID: 14:00 18:00
Institutionen för TENTAMEN CTH HT-14 Datavetenskap 2015-01-14 TDA550 Tentamen för TDA550 Objektorienterad programvaruutveckling IT, fk DAG: 15-01-14 TID: 14:00 18:00 Ansvarig: Christer Carlsson, ankn 1038
Läs merSubklasser och arv Inledning till grafik (JFrame och JPanel). Något om interface. Objektorienterad programvaruutveckling GU (DIT011) Subklasser
Institutionen för Datavetenskap Göteborgs universitet HT2009 DIT011 Objektorienterad programvaruutveckling GU (DIT011) Föreläsning 5 Innehåll Subklasser och arv Inledning till grafik (JFrame och JPanel).
Läs merLösningsförslag till tentamen
Uppgift 1 Lösningsförslag till tentamen 140828 a) public class MyMax { public static void main(string[] args) { //5 ändra String till String[] System.out.println("Maximum is: " + maximum(5, 7)); //2 ändra
Läs merTDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 2
TDA550 Objektorienterad programvaruutveckling IT, forts. kurs Övning vecka 2 Pelle Evensen, Daniel Wetterbro 20 oktober 2011 Sammanfattning Denna vecka ska vi titta på skillnader mellan primitiva typer
Läs merSprå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
Läs merOOP 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
Läs merTDDC77 Objektorienterad Programmering
TDDC77 Objektorienterad Programmering Föreläsning 2 Sahand Sadjadee IDA, Linköpings Universitet Hösttermin, 2018 Outline Emacs Introduktion till Objektorienterad Programmering Introduktion till Java Variabler
Läs merTENTAMEN OOP
TENTAMEN OOP 2014-01-19 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
Läs merObjektorienterad Programkonstruktion. Föreläsning 11 6 dec 2016
Objektorienterad Programkonstruktion Föreläsning 11 6 dec 2016 Föreläsningen 13/12 Halvtidsrepetition Maila frågor som ni vill att jag tar upp! ccs@kth.se Processer Vad vi i dagligt tal menar när vi pratar
Läs merTENTAMEN: Objektorienterad programmering. Läs detta! Skriv din tentamenskod på varje blad (så att vi inte slarvar bort dem).
1 (7) TENTAMEN: Objektorienterad programmering Läs detta! Uppgifterna är inte ordnade efter svårighetsgrad. Börja varje hel uppgift på ett nytt blad. Skriv inte i tesen. Ordna bladen i uppgiftsordning.
Läs merLÖ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
Läs mer