Skapa, kopiera och destruera klassobjekt
|
|
- Anna Svensson
- för 6 år sedan
- Visningar:
Transkript
1 LINKÖPINGS TEKNISKA HÖGSKOLA Institutionen för datavetenskap Avdelningen för Programvara och system Tommy Olsson Skapa, kopiera och destruera klassobjekt Detta dokument tar upp viktiga, grundläggande saker att tänka på då man konstruerar klasser. Initiera datamedlemmar i samma ordning som de deklareras Datamedlemmar initieras alltid i den ordning som de deklareras i klassdefinitionen. Datamedlemmar av grundläggande typ eller pekare har dock ingen defaultinitiering. Skriv alltid initierare i konstruktorer i samma ordning som medlemmarna deklareras, för att överensstämma med den ordningsom de kommer att initieras. Man undviker då irriterande varningar från kompilatorn. Exempel (felaktigt!): class Employee Employee(const string& firstname, const string& lastname) : firstname_name}, lastname_lastname}, _firstname_ +. + lastname_ } } private: string _; string firstname_; string lastname_; Eftersom _ är deklarerad före firstname_ och lastname_ kommer _ att initieras först och då använda de ännu ej initierade medlemmarna firstname_ och lastname_. Om definitionen för konstruktorn skrivs separat blir det ännu svårare att observera felet. Exekveringsfel kan bli följden. I C++11 kan man initiera datamedlemmar redan i deras deklaration, vilket man bör utnyttja. Om det även finns en initierare i en konstruktor är det inget problem, i så fall är det konstruktorns initiering som gäller. Detta är speciellt intressant för klasser med flera konstruktorer och olika sätt att initiera objekt. Anm. Anledningen till att designbeslutet att medlemmar initieras i deklarationsordning är att säkerställa en unik destrueringsordning. I annat fall skulle destruktorn behöva kunna destruera medlemmarna i olika ordning, beroende på vilken konstruktor som skapat ett objekt. Den extra bokföring som det skulle kräva vore inte acceptabel. Det bästa är om man kan undvika att en medlems initiering är beroende av andra medlemmars initiering. I exemplet ovan är problemet enkelt att rätta till, antingen deklareras _ efter de andra eller så kan man använd parametrarna för att initiera _ och, i det senare fallet, skriva initierarna i samma ordning som medlemmarna deklareras. Vid härledning gäller samma regel, basklassubobjekt initieras i samma ordning som basklasserna deklareras och basklassubobjekt initieras före de vanliga datamedlemmarna. Använd hellre initiering än tilldelning i konstruktorer Klassmedlemmar av klasstyp defaultinitieras. Om man inte initierar sådana medlemmar och använder tilldelning i stället, enligt följande class Employee Employee(const string& firstname, const string& lastname) firstname_ = firstname; lastname_ = lastname; _ = firstname_ +. + lastname_ ; } 1 (6)
2 private: string _; string firstname_; string lastname_; kommer defaultinitiering ändå att göras motsvarande följande: class Employee Employee(const string& firstname, const string& lastname) : _}, firstname_}, lastname_} // Tilldelningarna enligt exemplet ovan } private: // Deklarationerna enligt exemplet ovan Medlemmarna initieras alltså av defaultkonstruktorn för string och tilldelas sedan med kopieringstilldelningsoperatorn för string. Vanligtvis behöver en tilldelningsoperator göra mer än en konstruktor, eftersom den opererar på ett redan existerande objekt. Förutom att initerare ofta ger bättre läsbarhet finns det alltså även en effektivitetsaspekt för medlemmar med defaultinitiering. Medlemmar som är konstanter eller referenser måste initieras. Det är inte tillåtet att använda tilldelning för sådana medlemmar, i analogi med att man i ett block inte kan deklarera en konstant, eller en referens, utan att initiera den och senare tilldela den ett värde. Då en konstruktor ska allokera resurser, till exempel dynamiskt minne (new), är det vanligtvis bättre eller nödvändigt att göra det i kroppen för konstruktorn. Om en resursallokering misslyckas kan till exempel andra, redan erhållna resutser, behöva återlämnas och det kan visa sig omöjligt att hantera om man allokerar resurser i samband med att initierare utförs. Basklassdestruktorer bör vara public och virtual eller protected och ej virtual När man härleder klasser är ofta syftet att använda objekten polymorft och definitivt så om det finns vanliga medlemsfunktioner som deklareras virtual. Det finns två huvudalternativ då det gäller hur en destruktor i en klass som är basklass bör deklareras. Om objekt ska kunna deallokeras via en basklasspekare måste basklassens destruktor vara public, för att det ska vara tillåtet (pekarens typ, den statiska typen, avgör), och virtual för att korrekt destruktor ska anropas initialt, dvs destruktorn för den dynamiska typen (objektets typ). class Base virtual ~Base(); class Derived : public Base ~Derived(); // Implicit virtual, liksom även den kompilatorgenererade hade varit Base* bp = new Derived; delete bp; // OK, ~Base() är public; virtual medför att ~Derived() anropas I annat fall kan basklassens destruktor vara protected och inte virtual. 2 (6)
3 class Base // Bör inte finnas några publika konstruktorer fristående Base-objekt kan inte destrueras protected: ~Base(); class Derived : public Base ~Derived(); Base b; Derived d; // Fel, ~Base() är inte public, objekt kan inte skapas // OK, ~Derived() är public (anropar ~Base som är protected) Om en klass är både basklass och ska kunna användas som en konkret klass för att skapa fristående objekt måste dock destruktorn vara public. En kompilatorgenererad destruktor är public och inte virtual, vilket inte passar på något av de två alternativen ovan. Det innebär att för härledda klasser måste vanligtvis en destruktor deklareras. Destruktorer ska aldrig misslyckas Destruktorer, funktioner som frigör resurser (till exempel delete) och funktioner som byter innehåll på två objekt (swap-funktioner i många fall), ska aldrig behöva misslyckas. En destruktor ska aldrig kasta undantag, noexcept. Glöm inte kopiering Det är lätt att glömma bort kopiering eftersom kompilatorn genererar kopieringskonstruktorn och kopieringstilldelningsoperatorn, om man inte deklarerar dem själv. Det finns i princip tre alternativ: Använd de kompilatorgenererade versionerna om de fungerar. Skriv både kopieringskonstruktorn och kopieringstilldelningsoperatorn om klassen ska ha kopiering men de kompilatorgenererade versionerna inte fungerar. Eliminera båda genom att deklarera dem deleted. Flyttversioner (se nedan) genereras inte. class T private: T(const T&) = delete; T& operator=(const T&) = delete; Att eliminera kopiering medför en del begränsningar, till exempel att sådana objekt inte kan lagras i en standardcontainer men det skulle man antagligen i vilket fall inte vilja. Flyttsemantik (move-semantik) Normalt bör en klass, om den har kopieringskonstruktor och kopieringstilldelningsoperator även, ha flyttkonstruktor (move-konstruktor) och flyttilldelningsoperator (move-tilldelningsoperator). T(T&&); T& operator=(t&&); // Flyttkonstruktor för T // Flyttilldelningsoperator för T En flyttkonstruktor flyttar innehållet från källobjektet till destinationsobjektet och nollställer sedan källobjektet. En flyttilldelningsoperator flyttar innehållet från högeroperanden till vänsteroperanden och nollställer sedan normalt källobjektet. 3 (6)
4 Kopiera och destruera konsekvent Om man definierar någon av kopieringskonstruktorn, kopieringstilldelningsoperatorn eller destruktorn för en klass behöver man antagligen definiera även de övriga, eftersom dessa tre är relaterade inbördes: om man har en egen kopieringskonstruktor eller kopieringstilldelningsoperator ska man antagligen ha även den andra, eftersom båda bör ha likartade egenskaper om man eliminerar kopieringskonstruktorn eller kopieringstilldelningsoperatorn ska man antagligen eliminera båda, eftersom kopiering med någon av dessa antagligen inte ska tillåtas om man har egna kopieringsfunktioner behöver man antagligen ha en egen destruktor om man har en egen destruktor behöver man antagligen ha egen kopiering eller eliminera kopiering tillåts kopiering bör antagligen även möjligheten att flytta objekt finnas Om kompilatorgenererade versioner fungerar är dessa att föredra framför egendefinierade, eftersom de kompilatorgenererade är triviala, vilket kan ha stor betydelse vid exempelvis optimering. Se upp med slicing Slicing av objekt uppstår när ett objekt av subklasstyp omvandlas till ett objekt av basklasstyp. Detta är en är lömsk omvandling eftersom den är osynlig och automatisk. Ett scenario kan se ut enligt följande. class Base Base(const Base&); virtual ~Base(); class Derived : public Base void fun(base b); // Kopieringskonstruktorn för Base gör kopian vid värdeöverföringen Derived d; fun(d); // Funktionen fun anropas med d, ett objekt av subtyp till Base Programmerarens avsikt är att funktionen fun() ska operera på objekt av typen Base och subtyper polymorft men glömde & efter Base i deklarationen av parametern b. När fun anropas med ett objekt av typen Derived, kommer kopieringskonstruktorn för Base att initiera b med en slajsad kopia av d. Avsikten var att en referensöverföring skulle ske, vilket inte påverkar det refererade objektet. Om man vill tillåta slicing under kontrollerade former kan man deklarera kopieringskonstruktorn explicit. Anropet av funktionen fun() ovan ger då ett kompileringsfel, eftersom användningen av kopieringskonstruktorn inte är explicit vid parameteröverföringen. Genom att deklarera kopieringskonstruktorn explicit elimineras dock all värdeöverföring, vilket bör vara förbehållet specialfall. class Base explicit Base(const Base&); void fun(const Base& rb) Base b(rb); // explicit användning av kopieringskonstruktorn för Base }. 4 (6)
5 Kopiering av polymorfa objekt Ett sätt att kopiera polymorfa objekt (man känner inte statiskt till typen för objekt som ska kopieras) är att använda en virtuell kopieringsfunktion, som clone() nedan. class Base virtual Base* clone() const = 0; protected: Base(const Base&); class Derived : public Base virtual Derived* clone() const override return Derived(*this); } protected: Derived(const Derived& other) : Baseother} } Det gäller att samtliga konkreta subklasser överskuggar clone() med en egen version som gör en korrekt kopia av subklassen ifråga. Märk alltid sådana överskuggningar med override, så uppmanas kompilatorn att kontrollera att det är korrekt. Alla klasser bör ha en swap-funktion om det är meningsfullt En swap-funktion byter innehåll på två objekt. Den är, förutom att byta innehåll på två objekt, även användbar för att implementera andra operationer. Deklarera en medlem och en icke-medlem, som då används i stället för std::swap. class T void swap(t& other); // ska helst inte kasta undantag swap(t& a, T& b); Ett exempel på användning av swap är för att implementera tilldelningsoperatorer: T& operator=(const T& rhs) T temprhs); // skapa en kopia händer det dåliga saker händer det här swap(temp); // och byt med *this return *this; // temp:s destruktor tar hand om skräpet } Se även nästa stycke för en variation på detta tema. 5 (6)
6 Egendefinierad kopieringstilldelningsoperator När man ska skriva en egen kopieringstilldelningsoperator för en typ T bör den normalt deklareras på den klassiska formen T& operator=(const T& rhs); Deklarera inte tilldelningsoperatorer virtual, det kan göra att tilldelning mellan olika typer av objekt möjliggörs. Det är i så fall bättre att ha en vanligt funktion, till exempel virtual void assign(const T&); operator= ska inte returnera const T&. Det förhindrar förvisso att skriva kod som (x = y) = z, men även att objekt av typen T kan lagras i standardcontainrar, vilka kräver att tilldelningsoperatorn returnerar T&. Gör alltid kopieringstilldelningsoperatorn felsäker och gärna enligt den starka garantin, dvs att inget minne läcker och inga objekt hamnar i ett odefinierat tillstånd. Se till att alla tilldelningsoperator är självtilldelningssäkra. Det bästa sättet att göra det är att använda idiomet skapa en temporär/kopia och byt, se ovan, det gör operatorerna både starkt felsäkra och självtilldelningssäkra. Anropa basklassers tilldelningsoperatorer uttryckligen och tilldela alla datamedlemmar. Returnera alltid *this. Undvik att anropa virtuella funktioner i konstruktorer och destruktorer Virtuella funktioner beter sig inte virtuellt i konstruktorer och destruktorer. Om en basklasskonstruktor eller -destruktor skulle vilja använda en härledd klass får man tillgripa andra tekniker, eftersom sammansatta objekt konstrueras subobjekt för subobjekt, uppifrån och ner enligt klasshierarkin. class Base Base() memfun(); } virtual void memfun(); class Derived : public Base Derived() memfun(); } virtual void memfun(); Derived d; När objektet d ovan konstrueras utförs först konstruktorn för Base. Medan det sker är den dynamiska typen för objektet Base, inte Derived (this-pekaren har typen Base* const, inte Derived* const). Ett anrop av den virtuella funktionen memfun() i konstruktorn för Base kommer alltså att anropa Base::memfun(). Efter att konstruktorn för Base är avslutad utförs konstruktorn för Derived och i dess kropp har this-pekaren nu typen Derived* const. Att det är Base::memfun() som anropas i konstruktorn för Base är bra, eftersom medlemmarna som tillhör Derived ännu inte är initierade men inte det som skulle behövas. Medan konstruktorn för Base utförs finns inget sätt att avgöra om det är ett fristående objekt som håller på att konstrueras eller om det är ett subobjekt i ett större sammansatt objekt. I vissa fall behövs så kallad post-construction, vilket innebär att en virtuell funktion anropas direkt efter att det fullständiga objektet har konstruerats. 6 (6)
TDDC76 - Programmering och Datastrukturer
TDDC76 - Programmering och Datastrukturer Klasser - speciella medlemsfunktioner Eric Elfving Institutionen för datavetenskap En klass ansvarar ofta för en resurs. Ibland är resursen så enkel som en datamedlem
TDIU01 Programmering i C++
TDIU01 Programmering i C++ Föreläsning 6 - Klasser Eric Elfving, eric.elfving@liu.se Institutionen för datavetenskap (IDA) Avdelningen för Programvara och system (SaS) Klasser När vi skapade vår lista
Operatoröverlagring. endast operatorsymboler definierade i C++ kan överlagras = += -= *= /= %= ^= &= = <<= >>= < > <= >= ==!= && > ->*, [ ] ( )
TDDC76 PoD OH Föreläsning C++ 83 Operatoröverlagring endast operatorsymboler definierade i C++ kan överlagras + - * / % ^ & ~! > = += -= *= /= %= ^= &= = = < > = ==!= && ++ -- -> ->*, [ ]
Innehåll. Konstruktorer vid arv Regler för basklassens konstruktor. Konstruktorer vid arv. Konstruktorer vid arv. Konstruktorer vid arv
Innehåll EDAF30 Programmering i C++ 9. Polymorfism och arv Sven Gestegård Robertz Datavetenskap, LTH 2017 1 Klasser Polymorfism och arv Konstruktorer och destruktorer Tillgänglighet Arv utan polymorfism
TDDC76 PoD OH Föreläsning C Härledda klasser
TDDC76 PoD OH Föreläsning C++ 97 Härledda klasser C++ har en relativt komplett och därmed komplicerad modell för härledning/arv stödjer flera sätt för subklasser att ärva från sina basklasser enkelt arv
Innehåll. 1 Kort om dynamisk polymorfism. 2 Arv i C++ 3 Multipelt arv. 4 Något om statisk polymorfism. class Container {
Innehåll EDAF30 Programmering i C++ Arv. Polymorfism. Sven Gestegård Robertz Datavetenskap, LTH 2015 1 Kort om dynamisk polymorfism Virtuella funktioner 2 Arv i C++ Konstruktorer och destruktorer Tillgänglighet
Dynamisk bindning och polymorfism
Dynamisk bindning och polymorfism I C++ är pekare till basklasser polymorfa, dvs de kan peka på objekt av en subklass typ Vid statisk bindning sker all bindning vid kompileringen -> Vid ett metodanrop
Lektionsuppgifter. TDDI14 Objektorienterad programmering. Lektionsplanering Lektion Lektion Lektion
LINKÖPINGS TEKNISKA HÖGSKOLA Institutionen för datavetenskap Programvara och system Tommy Olsson 2014-02-05 Lektionsplanering.................................. 2 Lektion 1..........................................
Introduktion till arv
Introduktion till arv 6 INTRODUKTION TILL ARV Arv Generell-Speciell Arv för att utnyttja det vi redan gjort Återanvändning Basklass Härledd klass Varför arv? Inför en subklass för att uttrycka specialisering
Programmering i C++ EDA623 Arv. EDA623 (Föreläsning 6) HT 2013 1 / 42
Programmering i C++ EDA623 Arv EDA623 (Föreläsning 6) HT 2013 1 / 42 Arv Innehåll Härledda klasser Konstruktorer och destruktorer vid arv Tillgänglighet Polymorfism och dynamisk bindning Abstrakta klasser
Del2 Klasser, medlemmar och arv Ämnesområden denna föreläsning:
2D1387, Programsystemkonstruktion med C++ 00/01 1 Del2 Klasser, medlemmar och arv Ämnesområden denna föreläsning: Klasser, åtkomst Medlemmar, medlemsfunktioner, inline Slide 1 Konstruktorer Destruktorer
Programmering i C++ EDA623 Objektorienterad programutveckling. EDA623 (Föreläsning 5) HT 2013 1 / 33
Programmering i C++ EDA623 Objektorienterad programutveckling EDA623 (Föreläsning 5) HT 2013 1 / 33 Objektorienterad programutveckling Innehåll Grundläggande begrepp Relationer mellan objekt Grafisk representation
Klasser. Kapitel 2. Kapitel 2 - Klasser, medlemmar och arv. Klasser. Klasser Medlemmar Arv
Kapitel 2 Klasser Medlemmar Arv, medlemmar och arv Klasser, åtkomst Medlemmar, medlemsfunktioner, inline och destruktorer this-pekaren Arv, åtkomst Multipelt arv, virtuell basklass Konstanta funktioner
Objektorientering - Arv och polymorfi. Eric Elfving Institutionen för datavetenskap
Objektorientering - Arv och polymorfi Eric Elfving Institutionen för datavetenskap 1 / 25 Med hjälp av arv kan vi bryta ut saker som är gemensamt hos flera klasser. Vi får också möjlighet att referera
Innehåll. Typomvandlingar (casting) Implicita Typomvandlingar. Typomvandlingar (casting) Implicita Typomvandlingar
Innehåll EDAF30 Programmering i C++ 9. Polymorfism och arv Sven Gestegård Robertz Datavetenskap, LTH 2016 1 Typomvandling 2 Klasser Polymorfism och arv Konstruktorer och destruktorer Tillgänglighet Arv
TDDC76 - Programmering och Datastrukturer
TDDC76 - Programmering och Datastrukturer Objektorientering - Arv och polymorfi Eric Elfving Institutionen för datavetenskap 1 / 25 Med hjälp av arv kan vi bryta ut saker som är gemensamt hos flera klasser.
Introduktion. Klasser. TDP004 Objektorienterad Programmering Fö 2 Objektorientering grunder
Introduktion TDP004 Objektorienterad Programmering Fö 2 Objektorientering grunder OO är den mest använda programmeringsparadigmen idag, viktigt steg att lära sig och använda OO. Klasser är byggstenen i
Programsystem konstruktion med C++ (2D1387) Innehåll. övning 2 klasser och arv
Programsystem konstruktion med C++ (2D1387) övning 2 klasser och arv Ronnie Johansson rjo@nadakthse grupp 4 2003 09 25 Innehåll Klasskonstruktorer och initieringslistor Klassdestruktorer Åtkomstkontroll
Kommentarer till Person
TDDC76 PoD OH Föreläsning C++ 97 Härledda klasser TDDC76 PoD OH Föreläsning C++ 98 --Manager-Consultant en polymorf klasshierarki C++ har en relativt komplett och därmed komplicerad modell för härledning/arv
Operatoröverlagring. 1 Definition och deklaration av operatorfunktioner. 2 Anrop av operatorfunktioner
En operator är i princip en funktion. Den utför en beräkning grundat på sina argument och ger ett värde som resultat. Det som skiljer en operatorfunktion från en vanlig funktion är dess namn och hur den
Innehåll. Användardefinierade typer. Användardefinierade typer Kategorier. Konstruktorer. Konstruktorer Två sätt att skriva initiering av medlemmar
Innehåll EDAF30 Programmering i C++ 3. Mer om klasser. Funktionsanrop Sven Gestegård Robertz Datavetenskap, LTH 2017 1 Klasser pekaren this const för objekt och medlemmar Kopiering friend inline 2 Funktionsanrop
Innehåll. Pekaren this Självreferens. Klasser Resurshantering, representation. Överlagring av operatorer. Överlagring av operatorer
Innehåll EDAF30 Programmering i C++ 8. Klasser; resurshantering och polymorfism Sven Gestegård Robertz Datavetenskap, LTH 2016 1 Klasser 2 Operatorer 3 Klasser, resurshantering Rule of three Move semantics
TDDI14 Objektorienterad programmering
LINKÖPINGS TEKNISKA HÖGSKOLA Institutionen för datavetenskap Avdelningen för programvara och system Tommy Olsson 2015-05-27 Datortentamen i TDDI14 Objektorienterad programmering Provkod DAT1 Datum 2015-06-01
Lite om felhantering och Exceptions Mer om variabler och parametrar Fält (eng array) och klassen ArrayList.
Institutionen för Datavetenskap Göteborgs universitet HT2009 DIT011 Objektorienterad programvaruutveckling GU (DIT011) Föreläsning 3 Innehåll Lite om felhantering och Exceptions Mer om variabler och parametrar
KLASSER. Inkapsling Abstrakt datatyp Public och private. Klassmedlemmar Datamedlemmar Exempel Funktionsmedlemmar
KLASSER Inkapsling Abstrakt datatyp Public och private Klassmedlemmar Datamedlemmar Funktionsmedlemmar Initiering av objekt Konstruktor Ta del av objektets tillstånd Förändra objektets tillstånd Avinitiera
Programsystemkonstruktion med C++: Övning 2. Karl Palmskog september 2010
Programsystemkonstruktion med C++: Övning 2 Karl Palmskog palmskog@kth.se september 2010 Specalfunktioner i klasser Konstruktorer i konstruktorerna för en klass initieras klassens medlemmar initialvärden
Objektorienterad programmering Föreläsning 12. Copyright Mahmud Al Hakim
Objektorienterad programmering Föreläsning 12 Copyright Mahmud Al Hakim mahmud@webacademy.se www.webacademy.se Agenda Introduktion till Arv Superklasser och Subklasser Dolda medlemmar (new och base) Statisk
allokeras på stacken dynamiskt new delete
Minneshantering Lokala objekt allokeras på stacken och har kort livslängd Objekt med längre livslängd måste allokeras dynamiskt på heapen (free store) Dynamisk allokering görs med new och delete Statiska
Minneshantering. Minneshantering. Minneshantering. Undvik pekare
Minneshantering Lokala objekt allokeras på stacken och har kort livslängd Objekt med längre livslängd måste allokeras dynamiskt på heapen (free store) Dynamisk allokering görs med new och delete Statiska
Innehåll. Pekare Exempel
Innehåll EDAF30 Programmering i C++ Avslutning. Sammanfattning och frågor 1 Syntax, förklaringar Sven Gestegård Robertz Datavetenskap, LTH 2016 2 Stack-allokering Heap-allokering: new och delete 3 Avslutning.
Innehåll. Pekare Exempel
Innehåll EDAF30 Programmering i C++ Avslutning. Sammanfattning och frågor 1 Syntax, förklaringar Sven Gestegård Robertz Datavetenskap, LTH 2017 2 Stack-allokering Heap-allokering: new och delete 3 Avslutning.
TDDC76 - Programmering och Datastrukturer
TDDC76 - Programmering och Datastrukturer Objektorientering - Arv och polymorfi Klas Arvidsson Institutionen för datavetenskap 1 / 33 UML UML är ett grafiskt språk som (bland mycket annat) används för
Kapitel 6 - Undantag
Kapitel 6 Undantag Kapitel 6 - Undantag Undantag (exceptions), returvärden throw, try och catch new, bad_alloc, nothrow Undantag och std::auto_ptr throw() i funktionsdeklaration try som funktionskropp
DD2387 Programsystemkonstruktion med C++ Tentamen 1 Torsdag 7 januari 2016, 14:00-18:00
DD2387 Programsystemkonstruktion med C++ Tentamen 1 Torsdag 7 januari 2016, 14:00-18:00 Introduktion Skriv dina svar på separata papper, dessa scannas in efter inlämning. Du kan skriva på både fram- och
Trädtraversering. Binärt träd. Trädtraversering djupet-först. Trädtraversering bredden-först
TDDI14 Objektorienterad programmering Fö: Binära träd, uttrycksträd 69 Binärt träd TDDI14 Objektorienterad programmering Fö: Binära träd, uttrycksträd 70 Trädtraversering struct Tree_Node Tree_Node(const
Idag. Javas datatyper, arrayer, referenssemantik. Arv, polymorfi, typregler, typkonvertering. Tänker inte säga nåt om det som är likadant som i C.
Idag Javas datatyper, arrayer, referenssemantik Klasser Arv, polymorfi, typregler, typkonvertering Strängar Tänker inte säga nåt om det som är likadant som i C. Objectorienterad programmering Sida 1 Ett
Nedan skapar vi klassen Person innehållande datamedlemmar för förnamn, efternamn, ålder, längd och vikt:
8. Objektorientering Skälet till att C++ är ett av de mest använda programspråken är att det är objektorienterat. Detta bygger vidare på begreppet struct (ursprungligen från språket C som inte är objektorienterat),
TDDC76 PoD OH Föreläsning C Klasser
TDDC76 PoD OH Föreläsning C++ 48 Klasser Ett posttyp class eller struct: komponenterna kallas medlemmar grundläggande är datamedlemmar och medlemsfunktioner struct används lämpligtvis då alla medlemmar
Klassmedlemmar. Klasser. Konstruktion av en enskild, icke-trivial klass. Klassen String funktionalitet
TDDC76 PoD OH Föreläsning C++ 48 Klasser Ett posttyp class eller struct: komponenterna kallas medlemmar grundläggande är datamedlemmar och medlemsfunktioner struct används lämpligtvis då alla medlemmar
Programmering i C++ EDA623 Mer om klasser. EDA623 (Föreläsning 6) HT 2013 1 / 26
Programmering i C++ EDA623 Mer om klasser EDA623 (Föreläsning 6) HT 2013 1 / 26 Mer om klasser Innehåll Konstanta objekt Statiska medlemmar Pekaren this Vänner (friends) Överlagring av operatorer EDA623
Inledande programmering med C# (1DV402) Tärningarna ska kastas
Tärningarna ska kastas Upphovsrätt för detta verk Detta verk är framtaget i anslutning till kursen Inledande programmering med C# vid Linnéuniversitetet. Du får använda detta verk så här: Allt innehåll
Java, klasser, objekt (Skansholm: Kapitel 2)
Java, klasser, objekt (Skansholm: Kapitel 2) Uppsala Universitet 11 mars 2005 Objectorienterad programmering Sida 1 Vad är en klass? En klass är ett sätt att beskriva en mängd objekt och deras gemensamma
Föreläsning 5 (6) Metoder. Metoder Deklarera. Metoder. Parametrar Returvärden Överlagring Konstruktorer Statiska metoder tostring() metoden javadoc
Föreläsning 5 (6) Metoder Metoder Parametrar Returvärden Överlagring Konstruktorer Statiska metoder tostring() metoden javadoc Metoder Deklarera public void setnamn(string n) Åtkomstmodifierare Returtyp
Övriga byggstenar. Övriga byggstenar. Några tips under programutveckling. Beroenden Pekare till funktioner Typkonvertering
Övriga byggstenar Beroenden Pekare till funktioner Övriga byggstenar Beroenden er Definitioners synlighet Funktionspekare Icke-medlemsfunktioner Medlemsfunktioner 2D1387 Programsystemkonstruktion med C++
Kopiering av objekt i Java
1 (6) Kopiering av objekt i Java Först När du läser detta papper bör du samtidigt studera dokumentationen för klasserna Object, Cloneable (java.lang) och ArrayList (java.util). Mycket blir klarare genom
Klasser. Konstruktion av en enskild, icke-trivial klass
TDDI14 Objektorienterad programmering Fö: Konstruktion av en enskild, icke-trivial klass 4 Klasser Konstruktion av en enskild, icke-trivial klass en egen strängklass String välkänd datatyp containerliknande
Klasser. Klassen String funktionalitet. Klassen String funktionalitet, forts. Klassen String funktionalitet, forts. Vad ska man kunna göra?
TDDI14 Objektorienterad programmering Fö: Konstruktion av en enskild, icke-trivial klass 4 Klasser Konstruktion av en enskild, icke-trivial klass en egen strängklass String välkänd datatyp containerliknande
5 Arv och dynamisk bindning FIGUR
5 Arv och dynamisk bindning Arv är en av hörnstenarna i objektorienterad programmering. Med hjälp av arv kan man skapa underhållsvänliga och förändringsvänliga system. Att hitta arvsrelationer är en viktig
Föreläsning 5-6 Innehåll. Exempel på program med objekt. Exempel: kvadratobjekt. Objekt. Skapa och använda objekt Skriva egna klasser
Föreläsning 5-6 Innehåll Exempel på program med objekt Skapa och använda objekt Skriva egna klasser public class DrawSquare { public static void main(string[] args) { SimpleWindow w = new SimpleWindow(600,
DAT043 - Föreläsning 7
DAT043 - Föreläsning 7 Model-View-Controller, mer om klasser och interface (arv, ) 2017-02-06 Designmönstret Observer avläser Observer Observable meddelar Observer avläser En eller flera objekt registrerar
F8: Typkonvertering i C++
Institutionen för datavetenskap Umeå Universitet F8: Typkonvertering i C++ Objektorienterad programmering för ingenjörer, VT04 Innehåll Implicit konvertering Konverteringskonstruktor Konverteringsoperator
Föreläsning 5-6 Innehåll
Föreläsning 5-6 Innehåll Skapa och använda objekt Skriva egna klasser Datavetenskap (LTH) Föreläsning 5-6 HT 2017 1 / 32 Exempel på program med objekt public class DrawSquare { public static void main(string[]
OOP Objekt-orienterad programmering
OOP F9:1 OOP Objekt-orienterad programmering Föreläsning 9 Arv och klasshierarkier Polymorfism OOP F9:2 Djur - String namn - int vikt + String getnamn() + int getvikt() + void ökavikt(int x) Ko - int mjölkvolym
Arv: Fordonsexempel. Arv. Arv: fordonsexempel (forts) Arv: Ett exempel. En klassdefinition class A extends B {... }
En klassdefinition class A extends B {... Arv definierar en klass A som ärver av B. Klassen A ärver alla fält och metoder som är definierade för B. A är en subklass till B. B är en superklass till A. class
Tentamen i TDP004 Objektorienterad Programmering Lösningsförslag
Tentamen i TDP004 Objektorienterad Programmering Lösningsförslag Datum: 2008-08-14 Tid: 08-12 Plats: PC6-PC7 i E-huset. Jour: Per-Magnus Olsson, tel 285607 Jourhavande kommer att besöka skrivsalarna varje
Kapitel 3. Synlighet. Kapitel 3 - Klassanvändning, operatorer och pekare. Synlighet
Kapitel 3 Klassanvändning Operatorer Pekare Kapitel 3 - Klassanvändning, operatorer och pekare Vänner till klasser och funktioner Virtuella funktioner och polymorfi Abstrakta basklasser och strikt virtuella
TDIU20 - Objektorienterad programmering i c++ - föreläsning 6
TDIU20 - Objektorienterad programmering i c++ - föreläsning 6 Pontus Haglund och Gustav L'estrade anpassade slides av Klas Arvidsson Department of Computer and information science 1 Arv (Specialisering)
Grundläggande programmering, STS 1, VT Sven Sandberg. Föreläsning 14
Grundläggande programmering, STS 1, VT 2007. Sven Sandberg Föreläsning 14 I torsdags & fredags: arrayer Deklaration, initiering, åtkomst Arrayer är referenser Arrayer som parametrar och returvärden Exempel
Tillämpad programmering
Tillämpad programmering C++ objekt Johan Montelius 1 struct struct Person { string name; int age; ; Person p; p.name = Joe ; p.age = 42; cout
TDDC76 Programmering och datastrukturer
TDDC76 Programmering och datastrukturer Arv, polymorfi och objektorienterad programmering Oskar Holmström Institutionen för datavetenskap Agenda 1 Pekare 2 Arv 3 Statisk bindning 4 Polymorfi 5 Destruktorer
C++ Objektorientering - Klasser. Eric Elfving
C++ Objektorientering - Klasser Eric Elfving 1 / 20 Återblick struct struct är bra att ha för att skapa aggregat - slå ihop flera data till en ny datatyp. Ett problem med struct är åtkomst... 2 / 20 Följande
Tommy Färnqvist, IDA, Linköpings universitet
Föreläsning 11 Arv, polymorfi TDDD86: DALP Utskriftsversion av föreläsning i Datastrukturer, algoritmer och programmeringsparadigm 5 oktober 2015 Tommy Färnqvist, IDA, Linköpings universitet 11.1 Innehåll
Objektorienterad programmering
Objektorienterad programmering Föreläsning 7 Copyright Mahmud Al Hakim mahmud@webacademy.se www.webacademy.se Agenda Konstanter och readonly Statiska klasser Standardklassen Math Parameteröverföring Referensen
Övningar Dag 2 En första klass
Kurs i C++ Sid 1 (5) Övningar Dag 2 En första klass Denna övning går ut på att steg för steg bygga upp en klass och skapa objekt. Vi kommer att utgå från en sammansatt datatyp i en struct och parallellt
3. Minneshantering - (copy)konstruktorn, destruktorn och tilldelningsoperatorn
3. Minneshantering - (copy)konstruktorn, destruktorn och tilldelningsoperatorn Minneshantering har väldigt lite med objektorienterad programmering att göra, många objektorienterade programspråk implementerar
Synlighet. Namespace Scope-operatorn Klasser Vänner
Synlighet Namespace Scope-operatorn Klasser Vänner Synlighet Ett problem med moduler i C är att alla variabel- och funktionsnamn ligger globalt synliga. C++ botar detta genom att införa det mycket användbara
Del3 Klassanvändning, operatorer och pekare Ämnesområden denna föreläsning:
2D1387, Programsystemkonstruktion med C++ 00/01 1 Del3 Klassanvändning, operatorer och pekare Ämnesområden denna föreläsning: Synlighet Överlagring av operatorer Slide 1 Vänner till klasser och funktioner
Objekt och klasser - Introduktion. Objekt. SparKonto.java 2. SparKonto.java 1. Konton.java. Ett objekt har: Ett bankkonto
Objekt och klasser - Introduktion Objekt Ð Begreppet objekt Ð Hur klasser anvšnds fšr att skapa objekt Ð Fšr-definierade klasser Ð Metoder och parameteršverfšring Ð Definiera klasser Ð Modifierare Ð Statiska
public och private Obs: private inte skyddar mot access från andra objekt i samma klass.
public och private En metod som är public får anropas från alla metoder i alla klasser. Ett attribut som är public får avläsas och ändras från alla metoder i alla andra klasser. En metod som är private
C++ Objektorientering - Klasser. Eric Elfving Institutionen för datavetenskap
C++ Objektorientering - Klasser Eric Elfving Institutionen för datavetenskap 1 / 23 Återblick struct struct är bra att ha för att skapa aggregat - slå ihop flera data till en ny datatyp. Ett problem med
Objekt och klasser - Introduktion
Objekt och klasser - Introduktion Begreppet objekt Hur klasser används för att skapa objekt Fördefinierade klasser Metoder och parameteröverföring Definiera klasser Modifierare Statiska variabler och metoder
Malmö högskola 2007/2008 Teknik och samhälle
Laboration 9 Avsikten med denna laboration är att du ska jobba vidare med klasser. Uppgifterna går ut på att skriva metoder och att skriva konstruktorer. Laborationen bygger vidare på laboration 8. Skapa
Exempelvis pekarvariabler blir då lättare korrekt deklarerade och initierade.
Inledning Följande dokument används för att förmedla vanliga fel vi ser vid rättning av inlämnad kod. Observera att detta är generella punkter menat för alla C++-kurser vi håller och därmed kanske inte
TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 2 Jonas Lindgren, Institutionen för Datavetenskap, LiU
TDDC30 Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 2 Jonas Lindgren, Institutionen för Datavetenskap, LiU På denna föreläsning: Konstruktorer Statiska metoder & attribut
F8 - Arv. ID1004 Objektorienterad programmering Fredrik Kilander
F8 - Arv ID1004 Objektorienterad programmering Fredrik Kilander fki@kth.se Arv och subklasser Klasser innehåller attribut och beteenden En subklass ärver dessa från föräldern Detta ger: Återanvänd kod
UML. Klassdiagr. Abstraktion. Relationer. Överskugg. Överlagr. Aktivitetsdiagram Typomv. Typomv. Klassdiagr. Abstraktion. Relationer.
Översikt Klasshierarkier UML klassdiagram Relation mellan klasser mellan klasser och objekt Association ning ing andling Programmering tillämpningar och datastrukturer 2 UML UML Unified Modeling Language
Innehåll. Typomvandlingar (casting) Implicita Typomvandlingar. Typomvandlingar (type casts) Explicita, namngivna typomvandlingar (C++-11)
Innehåll EDAF30 Programmering i C++ 8. Typomvandlingar. Klasser: operatorer och polymorfism. 1 Typomvandlingar Sven Gestegård Robertz Datavetenskap, LTH 2017 2 Klasser Operatorer 3 Polymorfism och arv
Innehåll. 1 Typdeklarationer och typomvandling 2 Resurshantering. 3 Objektorientering, kort repetition. 4 Klasser
Innehåll EDAF30 Programmering i C++ Resurshantering. Objektorientering. Klasser. Sven Gestegård Robertz Datavetenskap, LTH 2015 1 Typdeklarationer och typomvandling 2 Resurshantering Stack-allokering Heap-allokering:
1 Klasser och objektorientering Vad är objektorientering?
1 Klasser och objektorientering Vad är objektorientering? Det finns olika synsätt på programmering, dessa olika synsätt kallas för paradigm. De vanligaste paradigmen är det imperativa/proceduriella, det
Polymorfi. Objektorienterad och komponentbaserad programmering
Polymorfi Objektorienterad och komponentbaserad programmering Polymorfi, mångtydighet Polymorfi innebär att en viss konstruktion kan exekveras på olika sätt Överlagring av metoder ger ett polymorft beteende
Arv. Fundamental objekt-orienterad teknik. arv i Java modifieraren protected Lägga till och modifiera metoder med hjälp av arv Klass hierarkier
Arv Fundamental objekt-orienterad teknik arv i Java modifieraren protected Lägga till och modifiera metoder med hjälp av arv Klass hierarkier Programmeringsmetodik -Java 165 Grafisk respresentation: Arv
Uppgiften är att beskriva en kvadrat i ett Java program. En första version av programmet skulle kunna se ut så här:
Att skapa en klass kvadrat Uppgiften är att beskriva en kvadrat i ett Java program. En första version av programmet skulle kunna se ut så här: public class Kvadrat { private int sida; Det var väl inte
Problemet. Vi har sett att vi kan ersätta de metoder vi ärver från överklassen med egen funktionalitet (polymorfism)
Föreläsning 5 Problemet Vi har sett att vi kan ersätta de metoder vi ärver från överklassen med egen funktionalitet (polymorfism) class Bil : public Fordon Bil(Person & owner) : Fordon(owner) } // Den
Innehåll. dynamisk bindning. och programmering CRC) u Arv, polymorfi och
Innehåll u OOP snabbintroduktion u Datatyper u Uttryck u Satser u Arv (intro) u Programvaruutveckling och programmering u Klassdesign och metodik (UML, CRC) u Arv, polymorfi och dynamisk bindning u Fält
Arv. Objektorienterad och komponentbaserad programmering
Arv Objektorienterad och komponentbaserad programmering Arv Regel nr 1: Ett objektorienterat språk ska tillåta inkapsling av data Regel nr 2: Ett objektorienterat språk ska tillåta arv Regel nr 3: Ett
Del2 Klasser, medlemmar och arv Ämnesområden denna föreläsning:
2D1387, Programsystemkonstruktion med C++ 01/02 1 Del2 Klasser, medlemmar och arv Ämnesområden denna föreläsning: Klasser, åtkomst Medlemmar, medlemsfunktioner, inline Slide 1 Konstruktorer och destruktorer
Kort om klasser och objekt En introduktion till GUI-programmering i Java
Kort om klasser och objekt En introduktion till GUI-programmering i Java Klasser En klass är en mall för hur man ska beskriva på något. Antag att vi har en klass, Bil. Den klassen innehåller en lista på
Arv bakgrund (kap. 9)
Föreläsning 4 Arv bakgrund (kap. 9) Hund pälsfärg favoritben smutsa_ned() ät_katt() Kanin pälsfärg slaktvikt smutsa_ned() Katt pälsfärg smutsa_ned() klös_soffa() Arv bakgrund Många klasser delar på egenskaper
TDDC76 - Programmering och Datastrukturer
TDDC76 - Programmering och Datastrukturer Objektorientering - Klasser Eric Elfving Institutionen för datavetenskap 1 / 20 Återblick struct struct är bra att ha för att skapa aggregat - slå ihop flera data
Initiering och tilldelning
Initiering och tilldelning Initiering och tilldelning Datatyper Inbyggda datatyper Abstrakta datatyper Konkreta datatyper Motiv för en mall för klassdefinitioner Exempel: "En (o)säker array" Konstruktor
Inkapsling tumregler. Åtkomstmodifikatorer, instantiering, referenser, identitet och ekvivalens, samt klassvariabler. public och private
Inkapsling tumregler Åtkomstmodifikatorer, instantiering, referenser, identitet och ekvivalens, samt klassvariabler Tobias Wrigstad (baserat på material från Tom Smedsaas) 5 november 2010 1. Man skall
Objektorienterade programmeringsspråk. Objektorienterade språk. Den objekt-orienterade modellen. Jämför med icke-oo
Objektorienterade språk Historik Simula 67 Smalltalk 80 Procedurorienterad programmering Subprogram Programbibliotek Dataorienterad programmering Abstrakta datatyper Objektbaserade språk, föregångare till
TENTAMEN CD5250. Objektorienterad programutveckling med C++, 5p. Datum: , Tid: 14:00-19:00
TENTAMEN CD5250 Objektorienterad programutveckling med C++, 5p Max poäng: 40 Betygsgränser: 3: 20 4: 28 5: 36 Datum: 1999-06-01, Tid: 14:00-19:00 Ansvarig: Ivica Crnkovic Upp till 5 poäng kan komma från
"Är en"-relation. "Har en"-relation. Arv. Seminarium 2 Relevanta uppgifter. I exemplet Boll från förra föreläsningen gällde
Föreläsning 7 "Har en"-relation Arv "Har en" "Är en" Superklassen Object Överskuggning Fordonsexempel Seminarium 2 Relevanta uppgifter Uppgift 31 I exemplet Boll från förra föreläsningen gällde följande
Classes och Interfaces, Objects och References, Initialization
Classes och Interfaces, Objects och References, Initialization Objekt-orienterad programmering och design (DIT953) Niklas Broberg/Johannes Åman Pohjola, 2018 Abstract class En abstract class är en class
Programsystemkonstruktion med C++
Programsystemkonstruktion med C++ Övning 2 Daniel Aarno bishop@kth.se Översikt övning 2 Klasser Konstruktorer Destruktorer Arv Virtuella funktioner Abstrakta klasser Operatorer Templateklasser Templatefunktioner
1. Klass med en dynamiskt allokerad variabel, definitionsfilen-del Klass med en dynamiskt allokerad variabel, inkluderingsfilen.
1. Klass med en dynamiskt inkluderingsfilen Klass2-1 1. Klass med en dynamiskt definitionsfilen-del 1 Klass2-2 #ifndef person #define person #include #include class Person private:
Tentamen EDAF30 Programmering i C++
LUNDS TEKNISKA HÖGSKOLA 1(6) Institutionen för datavetenskap Tentamen EDAF30 Programmering i C++ 2016 01 11, 8.00 13.00 Hjälpmedel: En valfri C++-bok. OH-bilderna från föreläsningarna är inte tillåtna.
(Man brukar säga att) Java är... Denna föreläsning. Kompilering av Java. Historik: Java. enkelt. baserat på C/C++ Allmänt om Java
(Man brukar säga att) Java är... Denna föreläsning Allmänt om Java Javas datatyper, arrayer, referenssemantik Klasser Strängar enkelt baserat på C/C++ objekt-orienterat från början dynamiskt utbyggbart
Föreläsning 4. Klass. Klassdeklaration. Klasser Och Objekt
Föreläsning 4 Klasser Och Objekt Klass Beskrivning av en objekttyp Beskriver egenskaper och beteende (fält och metoder) Klassen fungerar som en ritning Objekt skapas från klassbeskrivningen - instansieras