Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 12: More on references and.

Slides:



Advertisements
Similar presentations
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 5.
Advertisements

Eiffel: Analysis, Design and Programming Bertrand Meyer (Nadia Polikarpova) Chair of Software Engineering.
© Bertrand Meyer and Yishai Feldman Notice Some of the material is taken from Object-Oriented Software Construction, 2nd edition, by Bertrand Meyer (Prentice.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 7: References and Assignment.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer Lecture 3: Abstract Data Types.
Chair of Software Engineering 1 Introduction to Programming Bertrand Meyer Exercise Session November 2008.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 14: Container Data Structures.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 6.
1 Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 10.
George Blank University Lecturer. CS 602 Java and the Web Object Oriented Software Development Using Java Chapter 4.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 2: Dealing with Objects I.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer Lecture 15: Exception handling.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer Lecture 4: Objects.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 17: Topological Sort Algorithm.
Chair of Software Engineering Piotr Nienaltowski, , Concurrent Object-Oriented Programming Bertrand Meyer, Piotr Nienaltowski.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 14: Container Data Structures.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 2: Dealing with Objects I.
Principles of Object-Oriented Software Development The language Eiffel.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 6: Object Creation.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 4: The Interface of a Class.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer Lecture 12: Design by Contract™
Chair of Software Engineering ATOT - Lecture 8, 28 April Advanced Topics in Object Technology Bertrand Meyer.
Chair of Software Engineering OOSC Summer Semester Object-Oriented Software Construction Bertrand Meyer.
Chair of Software Engineering OOSC - Lecture 4 1 Object-Oriented Software Construction Bertrand Meyer.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 4: The Interface of a Class.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 9: Abstraction.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 7.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 18: Undo/Redo.
Chair of Software Engineering Concurrent Object-Oriented Programming Prof. Dr. Bertrand Meyer Lecture 9: Contracts and Inheritance (based on work with.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 12: More on references and.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 10.
Chair of Software Engineering ATOT - Lecture 11, 7 May Advanced Topics in Object Technology Bertrand Meyer.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 7: References and Assignment.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer Lecture 6: Genericity.
Chair of Software Engineering ATOT - Lecture 3, 7 April Advanced Topics in Object Technology Bertrand Meyer.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 7.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 6: Object Creation.
Software Verification Bertrand Meyer Chair of Software Engineering Lecture 2: Axiomatic semantics.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 10.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 5.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 7.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 9.
Chair of Software Engineering ATOT - Lecture 5, 14 April Advanced Topics in Object Technology Bertrand Meyer.
Chair of Software Engineering ATOT - Lecture 7, 23 April Advanced Topics in Object Technology Bertrand Meyer.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 20: Multiple inheritance.
Chair of Software Engineering OOSC - Summer Semester Object-Oriented Software Construction Bertrand Meyer.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 11.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 10.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 9: Abstraction.
Ranga Rodrigo. Class is central to object oriented programming.
10 Conversion. Let’s start with conformance Conformance determines when a type may be used in lieu of another. Conformance relies on inheritance. The.
© Bertrand Meyer and Yishai Feldman Notice Some of the material is taken from Object-Oriented Software Construction, 2nd edition, by Bertrand Meyer (Prentice.
CSCI-383 Object-Oriented Programming & Design Lecture 13.
© Bertrand Meyer and Yishai Feldman Notice Some of the material is taken from Object-Oriented Software Construction, 2nd edition, by Bertrand Meyer (Prentice.
More About Classes Ranga Rodrigo. Information hiding. Copying objects.
Chair of Software Engineering 1 Introduction to Programming Bertrand Meyer Exercise Session October 2008.
Encapsulation COMP 401, Fall 2014 Lecture 06 9/4/2014.
Chair of Software Engineering 1 Introduction to Programming Bertrand Meyer Exercise Session October 2008.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 6.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 4.
Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Chair of Software Engineering Complement to lecture 11 : Levenshtein.
Object-Oriented Programming Chapter Chapter
© Bertrand Meyer and Yishai Feldman Notice Some of the material is taken from Object-Oriented Software Construction, 2nd edition, by Bertrand Meyer (Prentice.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 6.
Chair of Software Engineering 1 Introduction to Programming Bertrand Meyer Exercise Session October 2008.
Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Exercise Session 4.
Einführung in die Programmierung Introduction to Programming Prof. Dr
Einführung in die Programmierung Introduction to Programming Prof. Dr
Einführung in die Programmierung Introduction to Programming Prof. Dr
Einführung in die Programmierung Introduction to Programming Prof. Dr
Presentation transcript:

Chair of Software Engineering Einführung in die Programmierung Introduction to Programming Prof. Dr. Bertrand Meyer Lecture 12: More on references and the dynamic model

2 Reading assignment for next week Chapters on  Syntax (12)  Inheritance (17)

3 Purpose of this lecture Few really new concepts, but gain a better understanding of the tricky matter of references Reminder on garbage collection and associated concepts

4 Assignment Replaces a value by another x y 2 0 p. set_coordinates (2, 1) 0 1 p

5 Setting fields (in routines of the class) class POSITION feature – Access x: REAL -- Horizontal position y: REAL -- Vertical position feature – Element change set_coordinates (xval, yval: REAL) -- Set coordinates to (`xval', `yval'). require x_positive: xval >= 0 y_positive: yval >= 0 do ensure x_set: x = xval y_set: y = yval end x := xval y := yval

6 class TWO_VALUES feature item : INTEGER right : TWO_VALUES set_fields (n : INTEGER ; r : TWO_VALUES) -- Reset both fields do item := n right := r end Effect of an assignment Reference types: reference assignment Expanded types: value copy item right i tem := n right := r t : TWO_VALUES... create t... t. set_fields (25, Void) 3

7 Abstraction and client privileges Read access if attribute is exported  a1. x is an expression!  An assignment a1. x := v would be syntactically illegal! (It would assign to an expression, like a + b := v ) If class A has an attribute x, what may a client class C do with for a1 of type A ? a1. x a1 : A a1 C A (A)(A) (C )(C ) x x

8 prepend animate append An object has an interface count stations first last

9 prepend animate append count first An object has an implementation count stations first last

10 Information hiding prepend animate append count stations first last

11 Applying abstraction principles Beyond read access: full or restricted write, through exported procedures. Full write privileges: set_x procedure, e.g. set_temperature (u : REAL) -- Set temperature value to u. do temperature := u end Clients will use x. set_temperature (21.5)

12 Abstraction and client privileges If class A has an attribute x, what may a client class C do with for a1 of type A ? a1. x a1 : A x C A x (A)(A) (C )(C ) Secret Read, restricted write Full write Read-only The attribute may be: a1. x invalid permitted in C (for access) Modify through a1. x a1. some_procedure a1. set_x (v )

13 Taking full advantage of a setter command set_temperature (u : REAL) -- Set temperature value to u. require not_under_minimum: u >= -273 not_above_maximum: u <= 2000 do temperature := u update_database ensure temperature_set: temperature = u end

14 Possible client privileges Secret Read, restricted write Full write Read-only The attribute may be: a1. att invalid permitted in C (for access) Modify through a1. att a1. some_procedure a1. set_att (v) If class A has an attribute att, what may a client class C do with for a1 of type A ? a1. att a1 : A att C A

15 C++, Java, C# convention An attribute is either private or public If public, it is available for both read and write!  v := a1. x  a1. x := v This is almost never acceptable Consequence: shadow every attribute with “getter function” This can be pretty tedious! In Eiffel: may export an attribute, but  Only for reading  Without the information that it is an attribute: it could be a function (Uniform Access principle)

16 Having it both ways It is possible to define a query as temperature: REAL assign set_temperature Then the syntax x. temperature := 21.5 is accepted as an abbreviation for x. set_temperature (21.5) Retains contracts and any other supplementary operations C# has a notion of “property” which pursues the same goal Not an assignment, but a procedure call

17 A linked list of strings Haldenegg item right Central item right Haupt- bahnhof item right (LINKABLE) first_element last_element active count 3 Parade- platz item right : inserting at the end (LINKABLE) 4

18 Inserting an item at the end extend (v : STRING) -- Add v to end. -- Do not move cursor. local p : LINKABLE [STRING] do create p. make (v) if is_empty then first_element := p active := p else last_element. put_right ( p) if after then active := p end end last_element := p count := count + 1 end

19 LINKABLE cells class LINKABLE feature item C : STRING -- Value in this cell right : LINKABLE -- Cell, if any, to which this one is chained put_right (other : like Current) -- Put other to the right of current cell. do right := other ensure chained : right = other end Haldenegg item right

20 Exercise (uses loops) Reverse a list! Halden- egg item right Central Haupt- bahnhof last_element first_element count 3 (LINKABLE) (LINKED_LIST) Parade- platz

21 Reversing a list

22 Reversing a list from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element pivot right i 12345

23 Reversing a list from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element pivot right i 12345

24 Reversing a list from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element pivot right i 12345

25 Reversing a list from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element pivot right i 12345

26 i i pivot Reversing a list from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element right 12345

27 The loop invariant from pivot := first_element first_element := Void until pivot = Void loop i := first_element first_element := pivot pivot := pivot. right first_element. put_right (i ) end first_element pivot right i Invariant: from first_element following right, initial items in inverse order; from pivot, rest of items in original order

28 The trouble with reference assignment A comfortable mode of reasoning: -- Here SOME_PROPERTY holds of a “Apply SOME_OPERATION to b” -- Here SOME_PROPERTY still holds of a This applies to “expanded” values, e.g. integers -- Here P (a) holds OP (b) -- Here P (a) still holds of a

29 Dynamic aliasing a, b: LINKABLE [STRING] create a.... a. put ("Haldenegg") ‏ b := a -- Here a. item has value "Haldenegg" b. put ("Paradeplatz") ‏ -- Here a. item has value ????? Haldenegg item right a b

30 On the other hand I heard that the boss’s cousin earns less -- than 50,000 francs a year “Raise Caroline’s salary by 1 franc” -- ????? Metaphors:  “The beautiful daughter of Leda”  “Menelas’s spouse”  “Paris’s lover” = Helen of Troy

31 Practical advice Reference assignment is useful It’s also potentially tricky As much as possible, leave it to specialized libraries of general data structures

32 Variants of assignment and copy Reference assignment (a and b of reference types): b := a Object duplication (shallow): c := a. twin Object duplication (deep): d := a. deep_twin Also: shallow field-by-field copy (no new object is created): e. copy (a) ‏

33 Shallow and deep cloning Initial situation: Result of: b := a c := a. twin d := a. deep_twin “Almaviva” name landlord loved_one O1 “Figaro” O2 “Susanna” O3 b “Almaviva” O4 c “Almaviva” O5 “Figaro” O6 “Susanna” O7 d a

34 Where do these mechanisms come from? Class ANY in the Eiffel “Kernel Library” Every class that doesn’t explicitly inherit from another is considered to inherit from ANY As a result, every class is a descendant of ANY.

35 Completing the inheritance structure A BDEC ANY NONE Inherits from

36 A related mechanism: Persistence a. store (file) ‏.... b := retrieved (file) Storage is automatic. Persistent objects identified individually by keys. These features come from the library class STORABLE. Needs to be improved, see “ “object test”

37 Objects and references States of a reference: Operations on references: create p p := q p := Void if p = Void then... VOIDATTACHED create p p := q (where q is attached) ‏ p := Void p := q (where q is void) ‏ p ATTACHED p VOID

38 The object-oriented form of call some_target. some_feature (some_arguments) ‏ For example: Paris. display Line6. extend (Station_Parade_Platz) ‏ x := a. plus (b) ???????

39 Infix and prefix operators In a − b the − operator is “infix” (written between operands) ‏ In − b the − operator is “prefix” (written before the operand) ‏

40 Operator features expanded class INTEGER feature plus alias "+" (other : INTEGER): INTEGER is -- Sum with other do... end times alias “*“ (other : INTEGER): INTEGER is -- Product by other do... end minus alias “-" : INTEGER is -- Unary minus do... end... end Calls such as i.plus (j) can now be written i + j

41 What we have seen  Playing with references: list reversal  Dynamic aliasing and the difficulties of pointers & references  Overall inheritance structure  Copy, clone and storage operations  Persistence closure  Infix & prefix operators

42 Reading assignment for next week Chapters on  Syntax (12)  Inheritance (17)