Blood, SWAT and Tears - om storforsk-prosjektet SWAT: Semantics-preserving Weaving - Advancing the Technology

Størrelse: px
Begynne med side:

Download "Blood, SWAT and Tears - om storforsk-prosjektet SWAT: Semantics-preserving Weaving - Advancing the Technology"

Transkript

1 Blood, SWAT and Tears - om storforsk-prosjektet SWAT: Semantics-preserving Weaving - Advancing the Technology Stein Krogdahl OMS-seminar, 9. november 2005 Inndeling av presentasjonen: Om administrasjon, penger og personer Hovedproblemstillingen i SWAT Litt om noen forskjellige felter prosjektet vil komme borti Noen ideer for arbeid og oppstart

2 SWAT: Semantics-preserving Weaving - Advancing the Technology NFR-prosjekt, Storforsk, oppstart august 2005 (i praksis desember/januar) Ved forskningsgruppen OMS (ved Ifi): Objektorientering, Modellering og Språk Totalramme 8 mill., Tre prosjekt-stipendiater, forskningsopphold, workshops, reiser, Deltakere: Øystein Haugen Stein Krogdahl (prosjektleder) Birger Møller-Pedersen Prosjekt-stipendiater: Jon Oldevik og Roy Grønmo (4 år: ¾ stip, ¼ Sintef) Institutt-stipendiat: Fredrik Sørensen (4 år: ¾ stip, ¼ undervisning) Kontakter/samarbeidspartnere: Andrew Black, Oregon State University, Portland, USA Jean-Marc Jezequel, INRIA & Univ. Rennes 1, Frankrike Ole Lehrman Madsen, Computer Science Dep. Aarhus University, Danmark Martin Odersky, Programming Methods Laboatory, EPFL, Lausanne, Sveits Jim Rumbaugh, IBM Rational, USA

3 Noen liknende prosjekter i vår nærhet - Families: - Arbeider med modellering av familier av programmer. - Kanskje kommer det en oppfølger, mest om standardisering - Creol-prosjektet - På PMA-gruppa: Arbeider med statisk typede OO-språk for distribuerte systemer - Programmene skal til en viss grad kunne forandres under veis. - Har også egenskaper mot mer formelle sider og mot verifikasjon - Prosjekt om Aspects in Modeling : - Hovedsakelig ved Colorado State University - Sentral: Robert B. France, som mange her har god kontakt med. - Det blir muligens et samarbeid med Sintef (med norske penger)

4 Hovedproblemstillingen i SWAT På øverste (og godt gammelt) nivå: Hvordan utforme et programmeringsspråk med best mulig støtte til: Separation of concerns: Forskjellige concerns, aspekter, etc. av problemstillingen/programmet kan programmeres mest mulig i sepatate program-moduler som er tekstlig sammenhengende, med en ramme rundt seg og som i størst mulig grad kan skrives, forstås, testes ut, vedlikeholdes osv. separat Orthogonal combination of modules: At disse program-moduler i størst mulig grad kan taes inn som en del av forskjellige programmer som trenger denne type funksjonalitet/egenskap, og at det da fungerer som tiltenkt, uten for mye gluecode. De samme problemene med modularisering eksisterer for modellering Vi tenker da mest på modellering som er knyttet til design-fasen Vi mener disse problemene er noe mindre studert for modellering enn for programmeringsspråk Og at det her kan være fruktbart å se på modellerings- og programmeringsspråk ut fra en bredere synsvinkel. Og ikke minst: Hva slags verktøy trenger man for effektivt å kunne ta i bruk slike språk?

5 SWAT s problemstilling: Ett nivå ned Kort SWAT-rettet historikk om modularisering (sett fra progr.språk) Først kom Fortran med aksjonspakker : Subrutiner (1957?). Rendyrket, og med blokkstruktur i Algol 60 (1958/60) Så kom Cobol med datapakker : Recorder (1959?) Så kom OO-begrepene som kombinerte dette, og la på mer (Simula 1967) Klasser og objekter Subklasser og subklasse-polymorfi Virtuelle metoder/prosedyrer/funksjoner Umiddelbart inspireret av dette kom (ca 1972) Abstrakte datatyper Som naturlig har private variable og (hjelpe) metoder Og et sett metoder som er synlige utenfra (operasjonene på ADT en) Til sammen var dette et meget store skritt framover, og det tok noe tid for fordøye dette: Så forslag til videre forbedringer kom ikke på en stund, DOG: Beta hadde klart nye ting, men fikk innflytelse på språkdesign først senere Multippel arv var det også mye snakk om (Eiffel og C++, og noe i Smalltalk) Rundt 1990 begynte det å skje en del (neste foil)

6 Rundt 1990 begynte det å skje en del Aspect-oriented programming Hvordan få samlet tekstlig ting som i den strukturen man har valgt ikke passer inn som en modul ( crosscutting concerns ). Generiske mekanismer (som var i Ada) kom nå i OO-språk Først i Eiffel, der det var noen teoretiske glipper i starten Begrepet virtuelle klasser fra Beta ble trukket fram bl.a. som et alternativ til generiske mekanismer. Man begynte å skille mellom interfacer (grensesnitt) og klasser (implementasjoner). Dette er for så vidt gammelt (ADT-er) men en ny vri med OO at disse kunne ha helt forskjellige arve-linjer. Det kom forskjellige mekanismer for å sette sammen kode-biter til f.eks. en klasse ( Traits, også part objects i Beta.) Språket Java kom (og senere C#), og dette gav et mer ryddig utgangspunkt for å diskutere varianter over OO-programmering. C++ har så mye rart at det lett ble unødvendig mye fikkel i diskusjonene

7 SWAT-drømmen Hver av disse mekanismene er blitt dyrket innenfor spesielle interesse-grupper som kan ha sin egen kultur som kanskje ikke er så innstilt på å se dem i sammenheng med andre liknende løsninger. SWAT-søknaden: La oss nå ta et skritt tilbake (i rom, ikke i tid!) og se på det som er foreslått, og finne det behov hver av dem dekker forsøke å finne mer enhetlige mekanismer som dekker flest mulige av disse behov med enklest mulige mekanismer. og ha tanke for både programmering og modellering samtidig De følgende foilene: Se noe nærmere på de forskjellige feltene listet opp på forrige foil

8 Aspect-Oriented Programming (AOP) Startet ca 1992 og fikk mer form ca. 1995, masse artikler, workshops etc. Viktige navn: Mehmet Aksit, Gregor Kiczales, Oscar Nierstrasz, Karl Lieberherr, Cristina Lopes, Lodewijk Bergmans Ide: Separation of concerns også for de concerns som ikke lar seg samle tekstlig med den hovedstrukturen programmet har. Slike concerns kalles crosscutting concerns altså behov som vil føre til tillegg mange steder i den eksisterende koden. Slike crosscutting concerns kan f.eks. være: Legge inn setninger for å lage trace av en eksekvering koordinering/synkronisering Sikkerhet:Sørge for at det blir tatt kopier av alle objekter på visse tidspunkt Spesiell terminologi: Join points: Sted man kan/skal legge inn ekstra kode Pointcuts: Mengder av join points Advice: Kode som legges inn ut fra et gitt pointcut. Weaving: Det å veve advice-koden inn på de rette steder.

9 Mer Aspect-Oriented Programming Det mest kjente språket for AOP er AspectJ (siste: AspectJ 5.0). Et annet er Hyper/J En forskjell: AspectJ gjør vevingen mer dynamisk enn Hyper/J Skal aspekter ha en interface/spesifikasjon slik at det kan sjekkes at et aspekt passer inn der man angir at det skal legges inn? Skal programmer som skal ta imot aspekter si noe om hva den vil akseptere (si hvordan de skal være spesifisert)? Eller skal skal alle aspekter kunne pådyttes alle program? Slik er det nok i AspectJ og Hyper/J Det blir svært lett dårlig interferens når man legger på flere aspekter Kan man skrive generelle aspekter som kan virker for mange programmer, og som f.eks. kan legges på et bibliotek? Skal et program kunne bygges opp bare av aspekter? Eller må du ha et grunn-program som man kan legge aspekter på?

10 Generiske mekanismer Generiske mekanismer, som var i Ada, kom nå også i OO-språk Problem: Om du fritt kan gi typer som runtime-parametere (til f.eks. prosedyrer eller klasser) så bryter statisk typesjekk sammen. Lar derfor slike parametere gies i en spesiell syntaks, og behandler dem grovt sett ferdig før eksekveringen. Generiske parametere kan være spesifiserte ( bounded ) eller uspesifiserte. Spesifiserte: Først i Eiffel (Bertrand Meyer, ca 1986) der det var noen teoretiske glipper i starten (rettet ca. 1990) Rettingene førte til F-bounded parameterization (en typeparameter kan selv forkomme i sin egen spesifikasjon: class C<T extends U<T>{ } ) Typisk uspesifiserte parametere: Templates i C++ (ca 1988) Generiske parametere må være spesifiserte for å kunne sjekke semantisk den parametriserte enheten (vanligvis en klasse). SWAT vil tenke i det!

11 Mer om generiske mekanismer Spesifiseringsmåter: Må være subklasser av eller implementere gitte klasser/interfacer (Vanligst) Må ha gitte prosedyrer/variable (Liskov/Bank/Myers, 1997) Nå er Java og C# kommet med generiske klasser. Ser nokså likt ut på overflaten, men er egentlig ganske forkjellige: Java ville ikke forandre byte-koden, så har måttet restriktere den generiske mekanismen nokså mye (ikke new T, der T er parameter) I C# ble ble bytekoden (CIL) forandret, så implementasjon kan være mer fullstendig.

12 Virtuelle klasser Beta (ca 1984, de kjente: Nygaard, Møller Pedersen, Lehrman Madsen, Bruun Kristensen) slo sammen prosedyrer og klasser til patterns, og fikk derfor virtuelle patterns (for hvertfall å dekke virtuelle prosedyrer) Man hadde dermed også fått virtuelle klasser, men dette ble først trukket fram i en artikkel i 1989 (Madsen og Møller-Pedersen). Virtuelle klasser er ikke statisk type-sjekkbart må ha run-time-tester (eller restriktere språket alvorligt) Virtuelle klasser kan også brukes til å parametrisere klasser (se neste foil) I 1997 foreslo Kresten.K.Thorup å inkludere virtuelle typer i Java (neste foil) Det har siden vært et stort antall artikler over temaene: Hva er fordeler/ulemper med å bruke virtuelle klasser/generiske parametere Hvordan kan vi begrense virtuelle klasser slik at de blir statisk type-sjekkbare, og at de samtidig er fleksible i bruk.

13 Thorups virtuelle klasser i Java: Syntaks og manglende statisk sjekkbarhet class A { typedef T as C; // C har metode m(int) T v1; ; v1.m(5); } class B extends A { typedef T as D; // D subklasse av C, har metode n(int); T v2; ; v2.m(5); ; v2.n(3); // Selvfølgelig! D v3 = v1; v1.n(3); // Men dette virker også } I et B-objekt vil også variablen v1 være typet med D (se siste linje over). T blir her en slags formell parameter til klassen A (som er spesifisert til å være en subklasse av C). For å få angitt en aktuell parameter til T må vi lage en subklasse B av A. Men det blir type-usikkert: A va; C cx; <va og cx har diverse tilordninger> ; va.v1= cx; Og kanskje peker va på et B-objekt og cx til et C-objekt. Det blir feil, og må testes for ved run-time (som for arrayer i Java).

14 Interfacer og implementasjon ble frigjort fra hverandre Skillet mellom interface og implementasjon er gammelt (ADT, Hoare ca 1972, inspirert av Simula) Dette ble også overført tilbake til OO, ved at man snakket om et objekts (eller en klasses) interface : ut fra hva klassen selv sa skulle være synlig utad Men det ble noe nytt når disse begrepene ble helt frigjort fra hverandre, ved at de kunne ha helt forskjellige arvelinjer og det var da f.eks. lett å lage mutippel arv for interfacer, selv om man ikke tillot det for klasser. Dette ble innført i Java, men var vel delvis brukt før det: I Smalltalk, der det fantes automatisk, fordi språket er helt dynamisk typet. I andre sammenhenger Henger nært sammen med debatten om subtyping =/= subclassing? Bl.a. Alan Snyder var sentral her (men mange fler)

15 Statisk komposisjon av programmer En tidlig erkjennelse var at man bruker arv/subklasser til hvertfall to ting: Til klassifisering av objekter (og det dertil hørende hierarki av typer) Til gjenbruk av kode, ved å plassere den så høyt som mulig i klasse-hierarkiet, eller ved å spesialisere en generell biblioteks-klasse ved å lage en subklasse. Men det var klart at det også var ting som ikke gikk så greit. F.eks.: Man ønsket en slags multippel arv -liknende mekanisme for å sette sammen kode (kanskje med kraftige rstriksjoner). Men brukt fullt ut blir multippel arv fort veldig kompliserende. Det er derfor kommet diverse forslag til å skille mellom mekanismer for: (1) klassifiering av objekter og (2) til gjenbruk av kode AOP kan til en viss grad brukes til det siste, og noen har stresset denne siden av AOP kraftig (setter hele programmet sammen av aspekter) Del-objekter i Beta løser noe av dette Det er foreslått skjemaer for multippel arv der man bare blir subklasse av én av de man arver fra, mens man samtidig kan ta inn kode fra et antall andre klasser. Et forslag det har vært mye snakk om i det siste er traits (neste foil)

16 Traits Hva er Traits? En/et (?) Trait er en samling metoder. Når man skal lage en klasse kan man først lage en kjerne (bl.a. med variablene), og så angi et antall Traits som man vil ha med. Nye Traits kunne også bygges av flere eksisterende Traits i flere steg Viktig at Traits skulle være en lettvektsmekansime. I utgangspunktet var Traits laget for Smalltalk, og da ble det få problemer med at ting skulle typesjekkes osv. Det arbeides nå med en variant av Traits for Java, med typesjekking og det hele (og lettvektsegenskapen kan nok da fort komme i fare). Sentrale personer: Andrew P. Black, Oscar Nierstrasz, Nathanael Schärli, Stéphane Ducasse, and Philip J. Quitslund, start ca 2003 Disse moderne Traits-arbeidere henviser også til gammelt arbeid (1982!): Gael Curry, Larry Baer, Daniel Lipkie and Bruce Lee, TRAITS: an Approach to Multiple Inheritance Subclassing Her foreslås en utvidelse av Simula 67, med noe som likner på multippel arv.

17 Oppgradering av pakke-begrepet Dette feltet springer ut av en følelse av at man må kunne ha større enheter enn klasser Som kan romme en mengde av klasser som hører logisk sammen Javas pakker er et OK første skritt, men bør bygges mer ut. Én løsning her kan være å lage et bedre utbygget system for klasser inne i klasser. Her stiller Beta sterkt (men ikke Java!) En annen løsning er å lage et oppgradert pakke begrep Dette kunne være et mer statisk begrep enn klasser, og kunne derfor få et enklere typesystem. Generiske pakker (med type-parametere), har vært foreslått Også: At det for pakker også finnes frittsvevende interfacer, og at pakker kan implementere disse. Og at pakker kan settes sammen mer fritt enn f.eks. i det nåværende Java Vi har arbeidet med Generiske pakker med litt attåt : GePEC (Generic Packages with Expandable Classes), som er foredratt om tidligere i OMS-serien.

18 Eksempel: Generisk pakke Graph generic package GRAPH expandable Node, Edge { // Oppgir de som kan ekspanderes. Fornuftig? class Node { Edge firstedge; / / First in the list of edges leaving this node Edge insertedgeto(node to){... } / / Delivers the inserted new edge } class Edge { Node from, to; Edge nextedge; / / Next in the list of edges leaving the same node void deleteme( ){... } } } Bruk: inst GRAPH Node =>City, Edge =>Road; expansion City { / / Expansion of Node String name; / / In some method: int n = firstedge.length; / / OK, as type of "firstedge" is now Road City c = new City(... ); Road r = insertedgeto(c); / / No co- or contra-variance problems... } expansion Road { / / Expansion of Edge int length; }

19 Andre ting prosjektet bør se på Språket Scala : Martin Odersky og hans Programming methods Laboratory (LAMP) Scala har egenskaper både som tradisjonelt OO-språk, og som funksjonelt språk. Har gode modulariserings-egenskaper. Beslektet med Families-prosjektet: Software Factories: J.Greenfield, K.Short, S.Cook, S.Kent Generative programming: Krzystof Czarnecki er sentral. Domain Specific Languages: Gammelt tema med fornyet interesse Class boxes: Oscar Nierstrasz Språket gbeta, Erik Ernst. Generalisering av Beta Har dynamisk arv

20 Tanker til inspirasjon for SWAT Mekanismene som er nevnt til nå er alle nyttige til sine ting men de er for mange for ett språk og de vil også lett snuble i beina på hverandre Generalisering og unifisering må til. Hvordan? Når man bruker AOP til å veve nye setninger inn mellom gamle setninger kan det svært lett ødelegge allerede etablerte egenskaper. Tilsvarende ting gjelder for Traits som blir satt sammen Vi har derfor lagt vekt på at vi ønsker mekanismer som er semantics preserving. Men lett å oppnå er det opplagt ikke! Vi har lagt vekt på å utvide veve-begrepet til all slags sammensetning av programmer på andre måter enn de direkte blir skrevet. F.eks. det at klasser og subklasser skrives hver for seg (det er viktig for fleksibiliteten!), men konkateneres til hele klasser før det lages objekter. Tilsvarende kan man tenke for generiske mekansimer, mixin-klasser og traits som settes sammen Kanskje kan dette inspirere til et videre perspektiv?

21 Ting å sette i gang med Først å fremst: Sette seg nøyere inn i det som er tenkt/skrevet innen de nevnte felter. Mer rundt GePEC: Ta nok en design-runde med GePEC ut fra ny forståelse. Lage en implementasjon av GepecJ (eller Gepec#?) Og forsøke dette ut i større programmeringssammenheng Tenke på UML 3.0? Lage gode verktøy omkring de språk vi designer. Og selvfølgelig: Arbeide fram søknader til PhD-opptaket, og da tenke på hva hver stipendiat skal konsentrere seg om. Arrangere prosjektmøter / Workshops der vi etter hvert også trekker inn våre utenlandske kontakter

Generiske mekanismer i statisk typede programmeringsspråk

Generiske mekanismer i statisk typede programmeringsspråk Generiske mekanismer i statisk typede programmeringsspråk Stein Krogdahl INF-5110, 28 april 2005 Temaer: Hva er generiske mekanismer, og hvorfor har vi dem? Hovedtyper av generiske mekanismer Hovedstrategier

Detaljer

Generiske mekanismer i statisk typede programmeringsspråk

Generiske mekanismer i statisk typede programmeringsspråk Generiske mekanismer i statisk typede programmeringsspråk Dette stoffet er Pensum, og det er bare beskrevet her Mye her er nok kjent stoff for mange INF5110 7. mai 2013 Stein Krogdahl 1 Hvordan kunne skrive

Detaljer

Generiske mekanismer i statisk typede programmeringsspråk

Generiske mekanismer i statisk typede programmeringsspråk Generiske mekanismer i statisk typede programmeringsspråk Stein Krogdahl INF-5110, 27 april 2006 Temaer: Hva er generiske mekanismer, og hvorfor har vi dem? Hovedtyper av generiske mekanismer Hovedstrategier

Detaljer

Generiske mekanismer i klasser og pakker

Generiske mekanismer i klasser og pakker Generiske mekanismer i klasser og pakker Stein Krogdahl OMS-seminar, 14. desember 2004 Noen temaer: Litt om de nye generiske mekanismene i Java 1.5 og C# 2.0 Hva kan være interessant ved å i stedet ha

Detaljer

Generiske mekanismer i statisk typede programmeringsspråk INF5110 April, 2009

Generiske mekanismer i statisk typede programmeringsspråk INF5110 April, 2009 Generiske mekanismer i statisk typede programmeringsspråk INF5110 April, 2009 Torsdag 30. april (skattedagen!): Mer om generering av maskinkode (Ferdig oppkopiert hefte deles ut) Tirsdag 5. mai: Mer av

Detaljer

Repitisjonskurs. Arv, Subklasser og Grensesnitt

Repitisjonskurs. Arv, Subklasser og Grensesnitt Repitisjonskurs Arv, Subklasser og Grensesnitt Subklasser Klasser i OO-programmering representerer typer av objekter som deler et sett med egenskaper. En subklasse har egenskapene til en klasse + ett sett

Detaljer

Kap 6.4: Typesjekking Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 19. og 23. mars Dagens tema: Typer og typesjekking

Kap 6.4: Typesjekking Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 19. og 23. mars Dagens tema: Typer og typesjekking Kap 6.4: Typesjekking Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 19. og 23. mars 2015 Dagens tema: Typer og typesjekking Hva er nå egentlig en «type» i et programmeringsspråk? Hvordan

Detaljer

AlgDat 10. Forelesning 2. Gunnar Misund

AlgDat 10. Forelesning 2. Gunnar Misund AlgDat 10 Forelesning 2 Oversikt Java repetisjon IDE eller teksteditor + kommandolinje? Java Collections and Generics Programvareutvikling En mengde mer eller mindre veldefinerte metoder (software engineering):

Detaljer

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse Dessverre litt få figurer INF 5110, 8/5-2012, Stein Krogdahl Byte-koden for Java og.nett (C#) http://en.wikipedia.org/wiki/java_bytecode_instruction_listings

Detaljer

AlgDat 12. Forelesning 2. Gunnar Misund

AlgDat 12. Forelesning 2. Gunnar Misund AlgDat 12 Forelesning 2 Forrige forelesning Følg med på hiof.no/algdat, ikke minst beskjedsida! Algdat: Fundamentalt, klassisk, morsomt,...krevende :) Pensum: Forelesningene, oppgavene (pluss deler av

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i INF3110/4110 Programmeringsspråk Eksamensdag: 3. desember 2004 Tid for eksamen: 9.00 12.00 Oppgavesettet er på 8 sider. Vedlegg:

Detaljer

Distribuerte objekter og objekt-basert mellomvare

Distribuerte objekter og objekt-basert mellomvare Distribuerte objekter og objekt-basert mellomvare INF 5040 H2006 foreleser: Frank Eliassen INF5040 Frank Eliassen 1 Hvorfor objekt-basert distribuert mellomvare? Innkapsling naturlig tilnærming til utvikling

Detaljer

Semantisk Analyse del III

Semantisk Analyse del III Semantisk Analyse del III Typesjekking Kapittel 6.4 08.03.2013 1 Datatyper og typesjekking Om typer generelt Hva er typer? Statisk og dynamisk typing Hvordan beskrive typer syntaktisk? Hvordan lagre dem

Detaljer

Distribuerte objekter og objekt-basert mellomvare

Distribuerte objekter og objekt-basert mellomvare Distribuerte objekter og objekt-basert mellomvare INF5040 foreleser: Olav Lysne Frank Eliassen, SRL & Ifi/UiO 1 Hvorfor objekt-basert distribuert mellomvare? Innkapsling naturlig tilnærming til utvikling

Detaljer

Datatyper og typesjekking

Datatyper og typesjekking Datatyper og typesjekking Om typer generelt Hva er typer? Statisk og dynamisk typing Hvordan beskrive typer syntaktisk? Hvordan lagre dem i kompilatoren? Gjennomgang av noen typer Grunntyper Type-konstruktører

Detaljer

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

Oppsummering. Kort gjennomgang av klasser etc ved å løse halvparten av eksamen Klasser. Datastrukturer. Interface Subklasser Klasseparametre Oppsummering Kort gjennomgang av klasser etc ved å løse halvparten av eksamen 2012. Klasser Interface Subklasser Klasseparametre Datastrukturer Hva er problemet? Oppgaven Emballasjefabrikken Renpakk skal

Detaljer

Datatyper og typesjekking

Datatyper og typesjekking Datatyper og typesjekking Om typer generelt Hva er typer? Statisk og dynamisk typing Hvordan beskrive typer syntaktisk? Hvordan lagre dem i kompilatoren? Gjennomgang av noen typer Grunntyper Type-konstruktører

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 Eksamensdag : Tirsdag 5. juni 2007 Tid for eksamen : 14.30-17.30 Oppgavesettet er på : 6 sider (pluss vedlegg) Vedlegg

Detaljer

Distribuerte objekter og objekt-basert mellomvare

Distribuerte objekter og objekt-basert mellomvare Distribuerte objekter og objekt-basert mellomvare INF 5040 H2004 foreleser: Frank Eliassen Frank Eliassen, SRL & Ifi/UiO 1 Hvorfor objekt-basert distribuert mellomvare?! Innkapsling " naturlig tilnærming

Detaljer

Anatomien til en kompilator - I

Anatomien til en kompilator - I Anatomien til en kompilator - I program Symboltabell tekst tokens syntaks-tre beriket syntaks-tre Finne struktur i programmet OK i henhold til grammatikk? Preprocessor Makroer Betinget kompilering Filer

Detaljer

Enkle generiske klasser i Java

Enkle generiske klasser i Java Enkle generiske klasser i Java Oslo, 7/1-13 Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo Del 1: Enkle pekere Før vi tar fatt på det som er nytt i dette notatet, skal vi repetere litt

Detaljer

Javas klasse-filer, byte-kode og utførelse (og litt om C# sin CIL-kode)

Javas klasse-filer, byte-kode og utførelse (og litt om C# sin CIL-kode) Javas klasse-filer, byte-kode og utførelse (og litt om C# sin CIL-kode) Disse foilene er pensum INF 5110, 30/4-2013, Stein Krogdahl Byte-koden for Java og.nett (C#) kan leses her: http://en.wikipedia.org/wiki/java_bytecode_instruction_listings

Detaljer

Anatomien til en kompilator - I

Anatomien til en kompilator - I Anatomien til en kompilator - I 5/22/2006 1 Framgangsmåte for automatisk å lage en scanner Beskriv de forskjellige token-klassene som regulære uttrykk Eller litt mer fleksibelt, som regulære definisjoner

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 - Kompilatorteknikk Eksamensdag : Onsdag 2. juni 2010 Tid for eksamen : 14.30-17.30 Oppgavesettet er på : 5 sider (pluss

Detaljer

2 Om statiske variable/konstanter og statiske metoder.

2 Om statiske variable/konstanter og statiske metoder. Litt om datastrukturer i Java Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo 1 Innledning Dette notatet beskriver noe av det som foregår i primærlageret når et Javaprogram utføres.

Detaljer

Litt om Javas class-filer og byte-kode

Litt om Javas class-filer og byte-kode Litt om Javas class-filer og byte-kode INF 5110, 11/5-2010, Stein Krogdahl (Dessverre litt få figurer) Disse formatene ble planlagt fra start som en del av hele Java-ideen Bt Byte-koden gir portabilitet

Detaljer

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

Konstruktører. Bruk av konstruktører når vi opererer med enkle klasser er ganske ukomplisert. Når vi skriver. skjer følgende: Konstruktører Bruk av konstruktører når vi opererer med "enkle" klasser er ganske ukomplisert. Når vi skriver Punkt p = new Punkt(3,4); class Punkt { skjer følgende: int x, y; 1. Det settes av plass i

Detaljer

Datatyper og typesjekking

Datatyper og typesjekking Datatyper og typesjekking Om typer generelt Hva er typer? Statisk og dynamisk typing Hvordan beskrive typer syntaktisk? Hvordan lagre dem i kompilatoren? Gjennomgang av noen typer Grunntyper Type-konstruktører

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 Eksamensdag : Tirsdag 6. juni 2006 Tid for eksamen : 09.00-12.00 Oppgavesettet er på : 5 sider Vedlegg : Intet Tillatte

Detaljer

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse. INF 5110, 10/5-2011, Stein Krogdahl

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse. INF 5110, 10/5-2011, Stein Krogdahl NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse Dessverre litt få figurer INF 5110, 10/5-2011, Stein Krogdahl Oversikt over Javas class-filer og byte-kode Disse formatene ble planlagt fra start

Detaljer

Datatyper og typesjekking

Datatyper og typesjekking Datatyper og typesjekking Om typer generelt Hva er typer? Statisk og dynamisk typing Hvordan beskrive typer syntaktisk? Hvordan lagre dem i kompilatoren? Gjennomgang av noen typer Grunntyper Type-konstruktører

Detaljer

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

Eksekveringsrekkefølgen (del 1) Oppgave 1. Eksekveringsrekkefølgen (del 2) Kommentar til oppgave 1. } // class Bolighus // class Bygning Oppgave 1 System.out.println( Bolighus ); // class Bolighus Hva blir utskriften fra dette programmet? class Blokk extends Bolighus{ // class Blokk IN105subclassesII-1 Eksekveringsrekkefølgen

Detaljer

Plan: Parameter-overføring Alias Typer (Ghezzi&Jazayeri kap.3 frem til 3.3.1) IN 211 Programmeringsspråk

Plan: Parameter-overføring Alias Typer (Ghezzi&Jazayeri kap.3 frem til 3.3.1) IN 211 Programmeringsspråk Plan: Parameter-overføring Alias Typer (Ghezzi&Jazayeri kap.3 frem til 3.3.1) Funksjonelle språk (Ghezzi&Jazayeri kap.7 frem til 7.4) Neste uke: ML Ark 1 av 16 Forelesning 16.10.2000 Parameteroverføring

Detaljer

2 Om statiske variable/konstanter og statiske metoder.

2 Om statiske variable/konstanter og statiske metoder. Gaustadbekkdalen, januar 22 Litt om datastrukturer i Java Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo Innledning Dette notatet beskriver noe av det som foregår i primærlageret når

Detaljer

Velkommen til INF Kompilatorteknikk

Velkommen til INF Kompilatorteknikk Velkommen til INF5110 - Kompilatorteknikk Kursansvarlige: Stein Krogdahl [steink@ifi.uio.no] Birger Møller-Pedersen [birger@ifi.uio.no] Eivind Gard Lund (hjelpelærer) [eivindgl@student.matnat.uio.no] Kursområdet:

Detaljer

INF1000: Forelesning 7

INF1000: Forelesning 7 INF1000: Forelesning 7 Klasser og objekter del 2 Konstruktører Static UML REPETISJON 2 Repetisjon Repetisjon forts. Verden består av objekter av ulike typer (klasser). Ofte er det mange objekter av en

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 - Kompilatorteknikk Eksamensdag : Onsdag 5. juni 2013 Tid for eksamen : 14.30-18.30 Oppgavesettet er på : Vedlegg :

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Side 1 Det matematisk-naturvitenskapelige fakultet Eksamen i: INF1010 Objektorientert programmering Eksamensdag: Onsdag 4. juni 2014 Tid for eksamen: 9:00-15:00 Oppgavesettet er på

Detaljer

Velkommen til INF5110 Kompilatorteknikk

Velkommen til INF5110 Kompilatorteknikk Velkommen til INF5110 Kompilatorteknikk 15. januar 2013 Kursansvarlige: Stein Krogdahl [steink@ifi.uio.no] Ragnhild Kobro Runde [ragnhilk@ifi.uio.no] Henning Berg (oblig-ansvarlig) [hennb@ifi.uio.no] Kursområdet:

Detaljer

INF1000: Forelesning 7. Konstruktører Static

INF1000: Forelesning 7. Konstruktører Static INF1000: Forelesning 7 Klasser og objekter del 2 Konstruktører Static UML REPETISJON 2 Repetisjon Verden består av objekter av ulike typer (klasser). Ofte er det mange objekter av en bestemt type. Objekter

Detaljer

Med Svarforslag UNIVERSITETET I OSLO. Det matematisk-naturvitenskapelige fakultet. 3 sider (side 6, 7 og 8, rives ut, fylles ut og leveres)

Med Svarforslag UNIVERSITETET I OSLO. Det matematisk-naturvitenskapelige fakultet. 3 sider (side 6, 7 og 8, rives ut, fylles ut og leveres) Eksamen i : Med Svarforslag UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet INF5110 - Kompilatorteknikk Eksamensdag : Onsdag 3. juni 2009 Tid for eksamen : 14.30-17.30 Oppgavesettet er

Detaljer

Hva er programmering og hva vil det si å lære det?

Hva er programmering og hva vil det si å lære det? Hva er programmering og hva vil det si å lære det? Begreper i programmeringsspråk Programmeringsprosess Pedagogisk opplegg Jens Kaasbøll, Institutt for informatikk, Universitetet i Oslo 1 Programmering

Detaljer

INF1010 våren januar. Objektorientering i Java

INF1010 våren januar. Objektorientering i Java INF1010 våren 2017 25. januar Objektorientering i Java Om enhetstesting (Repetisjon av INF1000 og lær deg Java for INF1001 og INF1100) Stein Gjessing Hva er objektorientert programmering? F.eks: En sort

Detaljer

Programmeringsspråk for nybegynnere. Krav til språket. Krav til språket. Krav til språket

Programmeringsspråk for nybegynnere. Krav til språket. Krav til språket. Krav til språket Programmeringsspråk for nybegynnere Krav til språket Hva om vi laget vårt eget språk til INF1000? Programmeringsspråket må være så enkelt som mulig. (Programmering er vanskelig nok som det er.) Hvilke

Detaljer

Ark 1 av 18. programmeringsspråkenes. Velkommen til IN 211. verden. IN 211 Programmeringsspråk

Ark 1 av 18. programmeringsspråkenes. Velkommen til IN 211. verden. IN 211 Programmeringsspråk Ark 1 av 18 IN 211 Programmeringsspråk Velkommen til programmeringsspråkenes verden IN 211 Forelesning 20.8.2001 Foreleser Ragnhild Kobro Runde E-post: ragnhilk@ifi.uio.no Kontor: 3345 Treffetid: torsdager

Detaljer

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

INF1010 våren 2008 Uke 4, 22. januar Arv og subklasser Emneoversikt subklasser INF1010 våren 2008 Uke 4, 22. januar Arv og subklasser Stein Gjessing Institutt for informatikk Mange flere eksempler på fellesøvelsene og neste forelesning 1 Generalisering - spesialisering

Detaljer

Runtime-omgivelser Kap 7 - I

Runtime-omgivelser Kap 7 - I Runtime-omgivelser Kap 7 - I Generelt Språk som bare trenger statiske omgivelser Språk som trenger stakk-orienterte omgivelser Språk som trenger mer generelle omgivelser Vel så riktig å si at forskjellige

Detaljer

2012 2a. C rc; void main() { rc = new C (); rc.m2(); } } INF 3110/ INF /28/13 1

2012 2a. C rc; void main() { rc = new C (); rc.m2(); } } INF 3110/ INF /28/13 1 2012 2a Vi tenker oss i denne oppgaven at vi har et Java-lignende språk hvor metoder kan ha lokalt definerte metoder. Dessuten kan man deklarere variable og metoder også på ytterste programnivå. Dette

Detaljer

INF1010 våren Arv og subklasser del 1

INF1010 våren Arv og subklasser del 1 INF1010 våren 2015 Torsdag 12. februar Arv og subklasser del 1 Stein Gjessing Institutt for informatikk Universitetet i Oslo 1 Når du har lært om subklasser kan du programmere med: Første uke: Spesialisering

Detaljer

IN1010 våren januar. Objektorientering i Java

IN1010 våren januar. Objektorientering i Java IN1010 våren 2018 23. januar Objektorientering i Java Om enhetstesting Om arrayer og noen klasser som kan ta vare på objekter Stein Gjessing Hva er objektorientert programmering? F.eks: En sort boks som

Detaljer

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

EKSAMEN I FAG TDT4100 Objekt-orientert programmering. Fredag 3. juni 2005 KL. 09.00 13.00 Side 1 av 6 NTNU Norges teknisk-naturvitenskapelige universitet BOKMÅL Fakultet for informasjonsteknologi, matematikk og elektroteknikk Institutt for datateknikk og informasjonsvitenskap EKSAMEN I FAG

Detaljer

Klasser, objekter, pekere og UML. INF1000 - gruppe 13

Klasser, objekter, pekere og UML. INF1000 - gruppe 13 Klasser, objekter, pekere og UML INF1000 - gruppe 13 Klasse Beskriver ofte ting fra den virkelige verden Veldig ofte et substantiv (Person, Bok, Bil osv.) class Person { String navn; int alder; } class

Detaljer

INF Notater. Veronika Heimsbakk 10. juni 2012

INF Notater. Veronika Heimsbakk 10. juni 2012 INF1010 - Notater Veronika Heimsbakk veronahe@student.matnat.uio.no 10. juni 2012 1 Tilgangsnivåer 2 CompareTo Modifier Class Package Subclass World public Y Y Y Y protected Y Y Y N no modifier Y Y N N

Detaljer

Kapittel 7: Mer om arv

Kapittel 7: Mer om arv Kapittel 7: Mer om arv Redigert av: Khalid Azim Mughal (khalid@ii.uib.no) Kilde: Java som første programmeringsspråk (3. utgave) Khalid Azim Mughal, Torill Hamre, Rolf W. Rasmussen Cappelen Akademisk Forlag,

Detaljer

INF3110 Programmeringsspråk. Velkommen til kurset INF 3110/4110. Programmeringsspråk 1/24

INF3110 Programmeringsspråk. Velkommen til kurset INF 3110/4110. Programmeringsspråk 1/24 Velkommen til kurset INF 3110/4110 Programmeringsspråk 1/24 Forelesning 1 20.8.2003 Først det praktiske Foreleser: Roger Antonsen E-post: rantonse@ifi.uio.no Kontor: rom 3403 Treffetid: etter avtale Undervisning

Detaljer

INF 3110/4110. Velkommen til kurset. Programmeringsspråk. Først det praktiske

INF 3110/4110. Velkommen til kurset. Programmeringsspråk. Først det praktiske Velkommen til kurset INF 3110/4110 Programmeringsspråk 1/24 Først det praktiske Foreleser: Roger Antonsen E-post: rantonse@ifi.uio.no Kontor: rom 3403 Treffetid: etter avtale Undervisning Forelesninger:

Detaljer

INF1010 våren Arv og subklasser del 1

INF1010 våren Arv og subklasser del 1 INF1010 våren 2016 Torsdag 4. februar Arv og subklasser del 1 Stein Gjessing Institutt for informatikk Universitetet i Oslo 1 Når du har lært om subklasser kan du programmere med: Første uke: Spesialisering

Detaljer

Repetisjon: Statiske språk uten rekursive metoder (C1 og C2) Dagens tema Kjøresystemer (Ghezzi&Jazayeri 2.6, 2.7)

Repetisjon: Statiske språk uten rekursive metoder (C1 og C2) Dagens tema Kjøresystemer (Ghezzi&Jazayeri 2.6, 2.7) Dagens tema Kjøresystemer (Ghezzi&Jazayeri.6,.7) Repetisjon Språk med rekursjon (C3) og blokker (C4) Statisk link Dynamisk allokering (C5) Parameteroverføring 1/5 Repetisjon: Statiske språk uten rekursive

Detaljer

Dagens tema Kjøresystemer (Ghezzi&Jazayeri 2.6, 2.7)

Dagens tema Kjøresystemer (Ghezzi&Jazayeri 2.6, 2.7) Dagens tema Kjøresystemer (Ghezzi&Jazayeri 2.6, 2.7) Repetisjon Språk med rekursjon (C3) og blokker (C4) Statisk link Dynamisk allokering (C5) Parameteroverføring 1/25 Forelesning 11 5.11.2003 Repetisjon:

Detaljer

Viktig. Rettet i koden. Obligatorisk oppgave 2 Litt flere detaljer om semantikksjekk og kodegenerering. Semantikksjekk

Viktig. Rettet i koden. Obligatorisk oppgave 2 Litt flere detaljer om semantikksjekk og kodegenerering. Semantikksjekk Obligatorisk oppgave 2 Litt flere detaljer om semantikksjekk og kodegenerering Viktig Ny patch (patch_oblig2.zip) er lagt ut (15/4) Oblig 1 vil bli rettet denne uken Sjekk om det er registrert at den er

Detaljer

Runtimesystemer Kap 7 - I

Runtimesystemer Kap 7 - I Runtimesystemer Kap 7 - I Språk som bare trenger statisk allokering Språk som trenger stakk-orientert allokering Språk som trenger mer generell allokering Forskjellige slags begreper i et gitt språk krever

Detaljer

Velkommen til INF Kompilatorteknikk

Velkommen til INF Kompilatorteknikk Velkommen til INF5110 - Kompilatorteknikk Kursansvarlige: Stein Krogdahl [steink@ifi.uio.no] Birger Møller-Pedersen [birger@ifi.uio.no] Magnus Haugom Christensen [magnushc@ifi.uio.no] Kursområdet: www.uio.no/studier/emner/matnat/ifi/inf5110/v12

Detaljer

INF Repetisjon: Hvordan bygge treet og analysere? 8. september Typisk situasjon. De problematiske syntaks-diagrammene

INF Repetisjon: Hvordan bygge treet og analysere? 8. september Typisk situasjon. De problematiske syntaks-diagrammene Dagens tema: INF 2100 8. september 2004 Mer om strukturen i treet og hvordan bygge det Testing av at navn er deklarert og brukt riktig Arbeid i gruppene neste uke: Oppgaver relevant for dette stadiet i

Detaljer

Velkommen til INF Kompilatorteknikk

Velkommen til INF Kompilatorteknikk Velkommen til INF5110 - Kompilatorteknikk Kursansvarlige: Stein Krogdahl [steink@ifi.uio.no] Birger Møller-Pedersen [birger@ifi.uio.no] Andreas Svendsen (hjelpelærer) [Andreas.Svendsen@sintef.no] Kursområdet:

Detaljer

Runtime-omgivelser Kap 7 - II

Runtime-omgivelser Kap 7 - II Runtime-omgivelser Kap 7 - II Dynamisk lager-allokering/når trenger vi en heap For objekter/recorder som allokeres dynamisk (new) og som man kan ha pekere til Gjelder ofte også array-objekter Under visse

Detaljer

Et større programeksempel. Hvordan løse et reelt problem med en objektorientert fremgangsmåte

Et større programeksempel. Hvordan løse et reelt problem med en objektorientert fremgangsmåte Et større programeksempel Hvordan løse et reelt problem med en objektorientert fremgangsmåte Plan for forelesingen Beskrive en større problemstilling Planlegge programmet Skrive koden, én klasse om gangen

Detaljer

Statisk semantisk analyse - Kap. 6

Statisk semantisk analyse - Kap. 6 Statisk semantisk analyse - Kap. 6 Generelt om statisk semantisk analyse Attributt-grammatikker Symboltabell Datatyper og typesjekking 3/15/11 1 Generelt om semantisk analyse Oppgave: Sjekke alle krav

Detaljer

En snarvei til INF2100

En snarvei til INF2100 Et eksperiment En snarvei til INF2100 I år skal vi gjenta forsøket: Kan INF1000-studenter med ekstra programmeringsbakgrunn klare å gjennomføre INF2100? Hva lærer man i INF2100? INF2100 Prosjektoppgave

Detaljer

Kap 6.3: Symboltabellen Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 17. mars Dagens tema:

Kap 6.3: Symboltabellen Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 17. mars Dagens tema: Kap 6.3: Symboltabellen Foiler ved Birger Møller-Pedersen Forelest av Stein Krogdahl 17. mars 2015 Hvordan holde greie på: Dagens tema: Hvilke navn har en deklarasjon på «dette» sted i programmet? Hva

Detaljer

INF1010 Arv. Marit Nybakken marnybak@ifi.uio.no 2. februar 2004

INF1010 Arv. Marit Nybakken marnybak@ifi.uio.no 2. februar 2004 INF1010 Arv Marit Nybakken marnybak@ifi.uio.no 2. februar 2004 Motivasjon Arv bruker vi så vi skal slippe å skrive oss i hjel. Når vi programmerer, prøver vi gjerne å modellere en del av verden ved hjelp

Detaljer

Forelesning inf Java 1

Forelesning inf Java 1 Forelesning inf1000 - Java 1 Tema: Javas historie Bestanddelene i et Java-program Programvariabler Ole Christian Lingjærde, 22. august 2013 Ole Chr. Lingjærde Institutt for informatikk 22. august 2013

Detaljer

Dagens tema: 12 gode råd for en kompilatorskriver

Dagens tema: 12 gode råd for en kompilatorskriver Dagens tema: 12 gode råd for en kompilatorskriver Hvordan sjekke navn? Testutskrifter 12 gode råd Hva skal gjøres med navn? Sjekking av navn En kompilator må også sjekke riktig navnebruk: Det må ikke forekomme

Detaljer

Statisk semantisk analyse - Kap. 6

Statisk semantisk analyse - Kap. 6 Statisk semantisk analyse - Kap. 6 Generelt om statisk semantisk analyse Attributt-grammatikker Symboltabell Datatyper og typesjekking 3110/4110-2004 5110-2009 3/3/2009 1 Generelt om semantisk analyse

Detaljer

Diverse eksamensgaver

Diverse eksamensgaver Diverse eksamensgaver Noen har fått den idé å lage et språk hvor klasser kan ha noe tilsvarende byvalue-result -parametere. Klasser har ingen konstruktører, og by-value-result parametere spesifiseres som

Detaljer

MED SVARFORSLAG UNIVERSITETET I OSLO. Det matematisk-naturvitenskapelige fakultet

MED SVARFORSLAG UNIVERSITETET I OSLO. Det matematisk-naturvitenskapelige fakultet MED SVARFORSLAG UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 - Kompilatorteknikk Eksamensdag : Onsdag 2. juni 2010 Tid for eksamen : 14.30-17.30 Oppgavesettet er

Detaljer

Arv. Book book1 = new Book(); book1. title = "Sofies verden" class Book { String title; } class Dictiona ry extends Book {

Arv. Book book1 = new Book(); book1. title = Sofies verden class Book { String title; } class Dictiona ry extends Book { Arv Arv (eng: inheritance) er en mekanisme for å bygge videre på eksisterende klasser og regnes ofte som varemerket til objektorientert programmering. Når arv brukes riktig, kan den gjøre koden ryddigere

Detaljer

INF Oblig 2 semantikksjekk og kodegenerering

INF Oblig 2 semantikksjekk og kodegenerering INF5110 - Oblig 2 semantikksjekk og kodegenerering Magnus Haugom Christensen Instituttet for Informatikk Universitetet i Oslo 27. Mars - 2012 Oversikt Informasjon Oppgaven Semantikksjekk Kodegenerering

Detaljer

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

< T extends Comparable<T> > Indre klasser mm. «Det du bør ha hørt om før oblig 4» < T extends Comparable > Indre klasser mm. «Det du bør ha hørt om før oblig 4» Strukturen i oblig 3 null null null null Personbeholder pl null null Person p "Adnan" michael@ifi.uio.no INF1010 21. februar

Detaljer

Etter uke 6 skal du. Introduksjon til objektorientert programmering. Hva skjedde ~1967? INF1001. Grunnkurs i objektorientert programmering

Etter uke 6 skal du. Introduksjon til objektorientert programmering. Hva skjedde ~1967? INF1001. Grunnkurs i objektorientert programmering Etter uke 6 skal du Kjenne til motivasjonen for objektorientert programmering Introduksjon til objektorientert programmering INF1001 Høst 2016 Forstå hva en klasse er, og forskjellen på klasse og objekt

Detaljer

Runtimesystemer - II. Funksjoner som parametere. Virtuelle metoder

Runtimesystemer - II. Funksjoner som parametere. Virtuelle metoder Runtimesystemer - II Funksjoner som parametere Virtuelle metoder Parameteroverføring Call by value Call by reference Call by value-result Call by name 04/04/14 1 FUNKSJONER SOM PARAMETERE 04/04/14 2 Eksempel

Detaljer

INF5110. Oblig 2 presentasjon

INF5110. Oblig 2 presentasjon INF5110 Oblig 2 presentasjon Informasjon Oppgaven Semantikksjekk Kodegenerering Bytecode-biblioteket Ant-targets Oppsummering Oversikt Informasjon Oblig 2 tilgjengelig på kurssiden Patch med testfiler

Detaljer

class Book { String title; } class Dictionary extends Book { int wordcount; } class CartoonAlbum extends Book { int stripcount; }

class Book { String title; } class Dictionary extends Book { int wordcount; } class CartoonAlbum extends Book { int stripcount; } Arv Arv (eng: inheritance) er en mekanisme for å bygge videre på eksisterende klasser og regnes ofte som varemerket til objektorientert programmering. Når arv brukes riktig, kan den gjøre koden ryddigere

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i : INF5110 - Kompilatorteknikk Eksamensdag : Onsdag 4. juni 2008 Tid for eksamen : 14.30-17.30 Oppgavesettet er på : 7 sider Vedlegg

Detaljer

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

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Dagens tema Litt mer om vanlige lister Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Nyttige varianter av lister: Stabler («stacks») (Big Java 15.5.1) Køer («queues») (Big Java 15.5.2)

Detaljer

Fra problem til program

Fra problem til program Fra problem til program Gitt et problem, hvordan går man fram for å programmere en løsning? UML klassediagrammer Enhetstesting Dokumentasjon Som student ønsker vi oss et program som kan holde oversikt

Detaljer

SOSI standard - versjon 4.0 1 Del 1: Regler for navning av geografiske elementer. DEL 1: Regler for navning av geografiske elementer

SOSI standard - versjon 4.0 1 Del 1: Regler for navning av geografiske elementer. DEL 1: Regler for navning av geografiske elementer SOSI standard - versjon 4.0 1 DEL 1: Regler for navning av geografiske elementer SOSI standard - versjon 4.0 2 INNHOLDSFORTEGNELSE DEL 1: Regler for navning av geografiske elementer 1 0 Orientering og

Detaljer

INF april, 2015 Stein Krogdahl Ifi, UiO. Svar på oppgaver til kap. 8. Ble lagt ut 24. april

INF april, 2015 Stein Krogdahl Ifi, UiO. Svar på oppgaver til kap. 8. Ble lagt ut 24. april INF5110 28. april, 2015 Stein Krogdahl Ifi, UiO Svar på oppgaver til kap. 8 Ble lagt ut 24. april 1 SVAR: Oppgave 8.1.c (fra boka) Lag for hånd TA-kode for følgende uttrykk: a * b + a * b * c Du skal ikke

Detaljer

OPPGAVE 1 OBLIGATORISKE OPPGAVER (OBLIG 1) (1) Uten å selv implementere og kjøre koden under, hva skriver koden ut til konsollen?

OPPGAVE 1 OBLIGATORISKE OPPGAVER (OBLIG 1) (1) Uten å selv implementere og kjøre koden under, hva skriver koden ut til konsollen? OPPGAVESETT 4 PROSEDYRER Oppgavesett 4 i Programmering: prosedyrer. I dette oppgavesettet blir du introdusert til programmering av prosedyrer i Java. Prosedyrer er også kjent som funksjoner eller subrutiner.

Detaljer

EKSAMEN. Dato: 9. mai 2016 Eksamenstid: 09:00 13:00

EKSAMEN. Dato: 9. mai 2016 Eksamenstid: 09:00 13:00 EKSAMEN Emnekode: ITF20006 Emne: Algoritmer og datastrukturer Dato: 9. mai 2016 Eksamenstid: 09:00 13:00 Hjelpemidler: Alle trykte og skrevne Faglærer: Jan Høiberg Om eksamensoppgavene: Oppgavesettet består

Detaljer

Viktig. Rettet i koden. Oppgaven. Obligatorisk oppgave 2 - Kort om oppgaven og litt informasjon. Fredrik Sørensen OMS-gruppen, IfI

Viktig. Rettet i koden. Oppgaven. Obligatorisk oppgave 2 - Kort om oppgaven og litt informasjon. Fredrik Sørensen OMS-gruppen, IfI Viktig Obligatorisk oppgave 2 - Kort om oppgaven og litt informasjon Fredrik Sørensen OMS-gruppen, IfI Ny patch (patch_oblig2.zip) legges ut på kurssiden i dag. Oblig 1 vil bli rettet denne uken Sjekk

Detaljer

programeksempel Et større En større problemstilling Plan for forelesingen Problemstillingen (en tekstfil) inneholdt ordet "TGA"

programeksempel Et større En større problemstilling Plan for forelesingen Problemstillingen (en tekstfil) inneholdt ordet TGA Et større programeksempel Hvordan løse et reelt problem med en objektorientert fremgangsmåte En større problemstilling I uke 4 skrev vi et program for å sjekke om et gen (en tekstfil) inneholdt ordet "TGA"

Detaljer

Dagens tema: Sjekking

Dagens tema: Sjekking Dagens tema Dagens tema: Sjekking Navnebinding (obligatorisk oppgave 3) Biblioteket Logging Riktig bruk av navn (frivillig) Typesjekking (frivillig) Hele prosjektet Strukturen til kompilatoren vår f.pas

Detaljer

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

Innhold uke 4. INF 1000 høsten 2011 Uke 4: 13. september. Deklarasjon av peker og opprettelse av arrayobjektet. Representasjon av array i Java INF høsten 2 Uke 4: 3. september Grunnkurs i Objektorientert Programmering Institutt for Informatikk Universitetet i Oslo Siri Moe Jensen og Arne Maus Mål for uke 4: Innhold uke 4 Repetisjon m/ utvidelser:

Detaljer

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

1- og 2-veis Innkapsling Java Stabel Kø Prio-kø Iterator. Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Dagens tema Litt mer om vanlige lister Enveis- og toveislister Innkapsling («boxing») (Big Java 6.8.5) Nyttige varianter av lister: Stabler («stacks») (Big Java 15.5.1) Køer («queues») (Big Java 15.5.2)

Detaljer

Runtimesystemer - II. Parameteroverføring Call by value Call by reference Call by value-result Call by name INF 3110/ INF

Runtimesystemer - II. Parameteroverføring Call by value Call by reference Call by value-result Call by name INF 3110/ INF Runtimesystemer - II Parameteroverføring Call by value Call by reference Call by value-result Call by name 3110/4110-2004 5110-2009 4/14/2009 1 by value parameteroverføring (verdioverføring) Kall: inc2(&y)

Detaljer

Introduksjon til objektorientert programmering

Introduksjon til objektorientert programmering Introduksjon til objektorientert programmering Samt litt mer om strenger og variable INF1000, uke6 Ragnhild Kobro Runde Grunnkurs i objektorientert programmering Strategi: Splitt og hersk Metoder kan brukes

Detaljer

Del 3: Evaluere uttrykk

Del 3: Evaluere uttrykk Del 3: Evaluere uttrykk Hva skal vi gjøre? Hvordan lagre Asp-verdier Hvilke operasjoner må jeg implementere? Er operasjonen lovlig? Utføre operasjonen Strukturen til interpreten vår f.asp 3&4 Interpret

Detaljer

Eivind Gard Lund. 24. Mars 2009 Foilene bygger på 2009 utgaven av Andreas Svendsen

Eivind Gard Lund. 24. Mars 2009 Foilene bygger på 2009 utgaven av Andreas Svendsen Eivind Gard Lund 24. Mars 2009 Foilene bygger på 2009 utgaven av Andreas Svendsen Informasjon Semantikksjekk Kodegenerering Oblig 2 tilgjengelig på kurssiden Bygger på deres oblig 1 kode. Det er lagt ut

Detaljer

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO UNIVERSITETET I OSLO Det matematisk-naturvitenskapelige fakultet Eksamen i IN 115 og IN 110 Algoritmer og datastrukturer Eksamensdag: 14. mai 1996 Tid for eksamen: 9.00 15.00 Oppgavesettet er på 8 sider.

Detaljer