CS 43111 Design Principles Hans Van Vliet, Software Engineering, Principles and Practice, 3 rd edition, John Wiley & Sons, 2008. Section 12.1. Robert C.

Slides:



Advertisements
Similar presentations
General OO Concepts and Principles CSE301 University of Sunderland Harry R. Erwin, PhD.
Advertisements

Object-Oriented Analysis and Design
OOP in Java Nelson Padua-Perez Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
© 2006 Pearson Addison-Wesley. All rights reserved4-1 Chapter 4 Data Abstraction: The Walls.
1 Chapter 6 Inheritance, Interfaces, and Abstract Classes.
Feb. 23, 2004CS WPI1 CS 509 Design of Software Systems Lecture #5 Monday, Feb. 23, 2004.
From Theory to Practice 1 OOP Overview Reminder – some OOD principles from previous lessons: –Class Inheritance vs. Object Composition –Program.
3/15/05H-1 © 2001 T. Horton CS 494 Object-Oriented Analysis & Design Evaluating Class Diagrams Topics include: Cohesion, Coupling Law of Demeter (handout)
CSCI-383 Object-Oriented Programming & Design Lecture 15.
CSSE501 Object-Oriented Development
Programming Languages and Paradigms Object-Oriented Programming.
C++ Object Oriented 1. Class and Object The main purpose of C++ programming is to add object orientation to the C programming language and classes are.
Introduction to Object-oriented programming and software development Lecture 1.
CISC6795: Spring Object-Oriented Programming: Polymorphism.
Introduction to Object Oriented Programming. Object Oriented Programming Technique used to develop programs revolving around the real world entities In.
1 Abstraction  Identify important aspects and ignore the details  Permeates software development programming languages are abstractions built on hardware.
Recap (önemli noktaları yinelemek) from last week Paradigm Kay’s Description Intro to Objects Messages / Interconnections Information Hiding Classes Inheritance.
1 Object-Oriented Software Engineering CS Interfaces Interfaces are contracts Contracts between software groups Defines how software interacts with.
CSC 395 – Software Engineering Lecture 12: Reusability –or– Programming was Bjarne Again.
Object-Oriented Software Development F Software Development Process F Analyze Relationships Among Objects F Class Development F Class Design Guidelines.
1 Computer Science 340 Software Design & Testing Inheritance.
CSSE501 Object-Oriented Development. Some OO Design Principles  Majority principles here come from: Design Principles in Java, Bob Tarr.
1/20/03A2-1 CS494 Interfaces and Collection in Java.
Chapter 8 Object Design Reuse and Patterns. Object Design Object design is the process of adding details to the requirements analysis and making implementation.
Implications of Inheritance COMP206, Geoff Holmes and Bernhard Pfahringer.
More Implications of Inheritance COMP204, Bernhard Pfahringer.
Design Patterns Gang Qian Department of Computer Science University of Central Oklahoma.
Topic 1 Object Oriented Programming. 1-2 Objectives To review the concepts and terminology of object-oriented programming To discuss some features of.
Programming in Java CSCI-2220 Object Oriented Programming.
1 CSC/ECE 517 Fall 2010 Lec. 3 Overview of Eclipse Lectures Lecture 2 “Lecture 0” Lecture 3 1.Overview 2.Installing and Running 3.Building and Running.
Elements of OO Abstraction Encapsulation Modularity Hierarchy: Inheritance & Aggregation 4 major/essential elements3 minor/helpful elements Typing Concurrency.
 All calls to method toString and earnings are resolved at execution time, based on the type of the object to which currentEmployee refers.  Known as.
Object-Oriented Modeling: Static Models. Object-Oriented Modeling Model the system as interacting objects Model the system as interacting objects Match.
Type Abstraction SWE Spring October 05Kaushik, Ammann Substitution Principle “In any client code, if supertype object is substituted.
Inheritance. Inheritance - Introduction Idea behind is to create new classes that are built on existing classes – you reuse the methods and fields and.
Chapter 3 Collections. Objectives  Define the concepts and terminology related to collections  Explore the basic structures of the Java Collections.
Testing OO software. State Based Testing State machine: implementation-independent specification (model) of the dynamic behaviour of the system State:
Object-Oriented Software Engineering Practical Software Development using UML and Java Chapter 6: Using Design Patterns.
Inheritance CSI 1101 Nour El Kadri. OOP  We have seen that object-oriented programming (OOP) helps organizing and maintaining large software systems.
Application development with Java Lecture 21. Inheritance Subclasses Overriding Object class.
Evaluating an Object-Oriented Design ©SoftMoore ConsultingSlide 1.
1 Inheritance Reserved word protected Reserved word super Overriding methods Class Hierarchies Reading for this lecture: L&L 9.1 – 9.4.
Data Design and Implementation. Definitions Atomic or primitive type A data type whose elements are single, non-decomposable data items Composite type.
Chapter 5 Classes and Methods II Lecture Slides to Accompany An Introduction to Computer Science Using Java (2nd Edition) by S.N. Kamin, D. Mickunas, E.
COM S 228 Introduction to Data Structures Instructor: Ying Cai Department of Computer Science Iowa State University Office: Atanasoff.
Lecture 2 Object-oriented programming. Definitions of OOP OOP is a programming paradigm, which utilizes encapsulation, inheritance and polymorphism. (From.
Object-Oriented Software Engineering Practical Software Development using UML and Java Modelling with Classes.
Terms and Rules II Professor Evan Korth New York University (All rights reserved)
CSC 205 Java Programming II Abstract Data Type. Abstraction The meaning of abstraction Abstraction arises from a recognition of similarities between certain.
 Description of Inheritance  Base Class Object  Subclass, Subtype, and Substitutability  Forms of Inheritance  Modifiers and Inheritance  The Benefits.
3/1/01H-1 © 2001 T. Horton CS 494 Object-Oriented Analysis & Design Evaluating Class Diagrams Topics include: Cohesion, Coupling Law of Demeter (handout)
CSCE 240 – Intro to Software Engineering Lecture 3.
Zach Tatlock / Winter 2016 CSE 331 Software Design and Implementation Lecture 12 Subtypes and Subclasses.
CSCI 383 Object-Oriented Programming & Design Lecture 15 Martin van Bommel.
CompSci 280 S Introduction to Software Development
Unified Modeling Language (UML)
Module Road Map Refactoring Why Refactoring? Examples
Inheritance and Polymorphism
CMPE 135: Object-Oriented Analysis and Design October 24 Class Meeting
Design Principles.
CSE 331 Subtyping slides created by Marty Stepp based on materials by M. Ernst, S. Reges, D. Notkin, R. Mercer, Wikipedia
Type Abstraction SWE Spring 2009.
Inheritance "Question: What is the object oriented way of getting rich? Answer: Inheritance.“ “Inheritance is new code that reuses old code. Polymorphism.
Subtype Polymorphism, Subtyping vs
Overview of Eclipse Lectures
Chapter 20 Object-Oriented Analysis and Design
CMPE 135 Object-Oriented Analysis and Design March 21 Class Meeting
Lecture 11 Abstract Data Type
Object-Oriented PHP (1)
Type Abstraction SWE Spring 2013.
Presentation transcript:

CS Design Principles Hans Van Vliet, Software Engineering, Principles and Practice, 3 rd edition, John Wiley & Sons, Section Robert C. Martin, Clean Code: A Handdbook of Agile Software Craftsmanship, Prentice Hall, Joshua Bloch, Effective Java, 2 nd edition, Addition Wesley, 2008.

2 CS 4311 Outline Encapsulate what varies Minimize access of members Favor composition over inheritance Program to interface Open-closed principle Liskov substitution principle Why?

3 CS 4311 Abstraction “Abstraction arises from a recognition of similarities between certain objects, situations, or processes in the real world, and the decision to concentrate upon those similarities and to ignore for the time being the differences.” Tony Hoare “An abstraction denotes the essential characteristics of an object that distinguish it from all other kinds of objects and thus provide crisply defined conceptual boundaries, relative to the perspective of the viewer.” Grady Booch Q: Examples in programming/code? Q: Why abstraction?

4 CS 4311 Encapsulation “Encapsulation is the process of compartmentalizing the elements of an abstraction that constitute its structure and behavior; encapsulation serves to separate the contractual interface of an abstraction and its implementation.” Grady Booch “Encapsulation is a mechanism used to hide the data, internal structure, and implementation details of an object. All interaction with the object is through a public interface of operations.” Craig Larman Q: Language constructs that support encapsulation? Q: Why encapsulation?

5 CS 4311 Minimize the Accessibility of Classes and Members Classes should be opaque Classes should not expose their internal implementation details Use getters and setters Compare public double speed; vs private double speed; public double getSpeed() { return speed; } public void setSpeed(double speed) { this.speed = speed; }

6 CS 4311 Minimize the Accessibility of Classes and Members Classes should be opaque Classes should not expose their internal implementation details Use getters and setters Compare public double speed; vs. private double speed; public double getSpeed() { return speed; } public void setSpeed(double speed) { this.speed = speed; } Is this better? Why?

7 CS 4311 Advantages of Minimizing Accessibility Centralized checking of constraints Add useful side-effects (monitoring) Decouple internal representation from function:  Improved encapsulation  Reduced coupling of components

8 CS 4311 Outline Encapsulate what varies Minimize access of members Favor composition over inheritance Program to interface Open-closed principle Liskov substitution principle

9 CS 4311 Composition vs. Subclassing Two different methods for code reuse Delegation (prototype) vs inheritance (OO) Black box vs. white/grey box reuse Q: pros and cons? which one to use? A B A B

10 CS 4311 Composition Method of reuse in which new functionality is obtained by creating an object composed of other objects  New functionality obtained by delegating to objects being composed Sometimes called aggregation or containment  Aggregation - when one object owns or is responsible for another object and both objects have identical lifetimes (GoF)  Aggregation - when one object has a collection of objects that can exist on their own (UML)  Containment - a special kind of composition in which the contained object is hidden from other objects and access to the contained object is only via the container object (Coad) A B

11 CS 4311 Advantages of Composition Contained objects are accessed by the containing class solely through their interfaces "Black-box" reuse, since internal details of contained objects are not visible Good encapsulation Fewer implementation dependencies Each class is focused on just one task (cohesion) The composition can be defined dynamically at run-time through objects acquiring references to other objects of the same type

12 CS 4311 Disadvantages of Composition Resulting systems tend to have more objects Interfaces must be carefully defined in order to use many different objects as composition blocks

13 CS 4311 Inheritance Method of reuse in which new functionality is obtained by extending the implementation of an existing object The generalization class (superclass) explicitly captures the common attributes and methods The specialization class (subclass) extends the implementation with additional attributes and methods A B

14 CS 4311 Advantages of Inheritance New implementation is easy, since most of it is inherited Easy to modify or extend the implementation being reused

15 CS 4311 Disadvantages of Inheritance Breaks encapsulation, since it exposes a subclass to implementation details of its superclass "White-box" reuse, since internal details of superclasses are often visible to subclasses Subclasses may have to be changed if the implementation of the superclass changes Implementations inherited from superclasses can not be changed at runtime.

16 CS 4311 Example (from Effective Java by Bloch) public class InstrumentedHashSet extends HashSet { private int addCount = 0; // The number of attempted element insertions public InstrumentedHashSet() { super(); } public boolean add(E e) { addCount++; return super.add(e); } public boolean addAll(Collection c) { addCount += c.size(); return super.addAll(c); } public int getAddCount() { return addCount; } } Variant of HashSet that tracks number of insertions

17 CS 4311 Example Variant of HashSet that tracks number of insertions Keep track of insertions Call super constructor public class InstrumentedHashSet extends HashSet { private int addCount = 0; // The number of attempted element insertions public InstrumentedHashSet() { super(); } public boolean add(E e) { addCount++; return super.add(e); } public boolean addAll(Collection c) { addCount += c.size(); return super.addAll(c); } public int getAddCount() { return addCount; } }

18 CS 4311 Example Variant of HashSet that tracks number of insertions When we add, update the counter public class InstrumentedHashSet extends HashSet { private int addCount = 0; // The number of attempted element insertions public InstrumentedHashSet() { super(c); } public boolean add(E e) { addCount++; return super.add(e); } public boolean addAll(Collection c) { addCount += c.size(); return super.addAll(c); } public int getAddCount() { return addCount; } }

19 CS 4311 Example: Test It---Add! public class InstrumentedHashSetTest { private InstrumentedHashSet public void setUp() { set = new InstrumentedHashSet (); public void testAdd() { assertEquals(0, set.getAddCount()); set.add("CS4311"); assertEquals(1, set.getAddCount()); set.add("Fun"); assertEquals(2, set.getAddCount()); } % java org.junit.runner.JUnitCore InstrumentedHashSetTest JUnit version Time: 0 OK (1 test)

20 CS 4311 Example: Test It---AddAll! public class InstrumentedHashSetTest { public void testAddAll() { set.addAll(Arrays.asList(new String[] {"CS4311", "Fun"})); assertEquals(2, set.getAddCount()); } % java org.junit.runner.JUnitCore InstrumentedHashSetTest JUnit version E Time: There was 1 failure: 1) testAddAll(InstrumentedHashSetTest) java.lang.AssertionError: expected: but was: at … FAILURES!!! Tests run: 2, Failures: 1

21 CS 4311 Example: Test it---AddAll! public class InstrumentedHashSetTest { public void testAddAll() { set.addAll(Arrays.asList(new String[] {"CS4311", "Fun"})); assertEquals(2, set.getAddCount()); } % java org.junit.runner.JUnitCore InstrumentedHashSetTest JUnit version E Time: There was 1 failure: 1) testAddAll(InstrumentedHashSetTest) java.lang.AssertionError: expected: but was: at … FAILURES!!! Tests run: 2, Failures: 1 Test success or failure? What went wrong?

22 CS 4311 Example: Investigate It! Look at the API document, e.g., JDK 8 says public boolean addAll(Collection c) of AbstractCollection Adds all of the elements in the specified collection to this collection (optional operation). …This implementation iterates over the specified collection, and adds each object returned by the iterator to this collection, in turn. … Look at the source code.  The internal implementation of addAll() in the superclass superclass invokes the add() method!  First we add 2 to addCount in InstrumentedHashSet’s addAll().  Then we invoke super’s addAll(). For each element, this addAll() invokes the add() method, which as overridden by InstrumentedHashSet adds one for each element.

23 CS 4311 Example: Investigate It! Look at the API document, e.g., JDK 7 says public boolean addAll(Collection c) of AbstractCollection Adds all of the elements in the specified collection to this collection (optional operation). …This implementation iterates over the specified collection, and adds each object returned by the iterator to this collection, in turn. Look at the source code.  The internal implementation of addAll() in the superclass superclass invokes the add() method!  First we add 2 to addCount in InstrumentedHashSet’s addAll().  Then we invoke super’s addAll(). For each element, this addAll() invokes the add() method, which as overridden by InstrumentedHashSet adds one for each element. Need to know the implementation details to get this right!

24 CS 4311 Example: Fix It! Variant of HashSet that tracks number of insertions public class InstrumentedHashSet extends HashSet { private int addCount = 0; // The number of attempted element insertions public InstrumentedHashSet() { super(c); } public boolean add(E e) { addCount++; return super.add(e); } public boolean addAll(Collection c) { addCount += c.size(); return super.addAll(c); } public int getAddCount() { return addCount; } }

25 CS 4311 Example: Fix It! Variant of HashSet that tracks number of insertions public class InstrumentedHashSet extends HashSet { private int addCount = 0; // The number of attempted element insertions public InstrumentedHashSet() { super(c); } public boolean add(E e) { addCount++; return super.add(e); } public boolean addAll(Collection c) { addCount += c.size(); return super.addAll(c); } public int getAddCount() { return addCount; } } Any concerns? Hint: Program to interface

26 CS 4311 Example: Composition Let’s write an InstrumentedSet class that is composed of a Set object. Our InstrumentedSet class will duplicate the Set interface, but all Set operations will actually be forwarded to the contained Set object. The contained Set object can be an object of any class that implements the Set interface (and not just a HashSet) InstrumentedSet Set

27 CS 4311 Example public class InstrumentedSet implements Set { private final Set s; private int addCount = 0; public InstrumentedSet() { s = new HashSet (); } public boolean add(E e) { addCount++; return s.add(e); } public boolean addAll(addAll(Collection c) { addCount += c.size(); return s.addAll(c); } public int getAddCount() { return addCount; }

28 CS 4311 Example: Forwarding methods public void clear() { s.clear(); } public boolean contains(E e) { return s.contains(e); } public boolean isEmpty() { return s.isEmpty(); } public int size() { return s.size(); } public Iterator iterator() { return s.iterator(); } public boolean remove(E e) { return s.remove(e); } public boolean containsAll(Collection c) { return s.containsAll(c); } public boolean removeAll(Collection c) { return s.removeAll(c); } public boolean retainAll(Collection c) { return s.retainAll(c); } public E[] toArray() { return s.toArray(); } public E[] toArray(E[] a) { return s.toArray(a); } public boolean equals(E e) { return s.equals(e); } public int hashCode() { return s.hashCode(); } public String toString() { return s.toString(); }

29 CS 4311 Coad's Rules Use inheritance only when all of the following criteria are satisfied:  A subclass expresses “is a special kind of” and not “is a role played by a.”  An instance of a subclass never needs to become an object of another class.  A subclass extends, rather than overrides or nullifies, the responsibilities of its superclass.  A subclass does not extend the capabilities of what is merely a utility class.  For a class in the actual Problem Domain, the subclass specializes a role, transaction or device.

30 CS 4311 Outline Encapsulate what varies Minimize access of members Favor composition over inheritance Program to interface Open-closed principle Liskov substitution principle

31 CS 4311 Program to an Interface, not an Implementation Q: interface vs. implementation? A sorted set class provides a “choose” operation that returns an arbitrary element contained in the set. You learned that the operation always returns the smallest element of the set. Is this an interface or implementation feature? Why? service provider service user Client > List > LinkedList ArrayList X

32 CS 4311 Interface Interfaces express types in a limited way. An interface is the set of methods one object knows that it can invoke on another object. An object can have many interfaces. Different objects can have the same type and the same object can have many different types. An object is known by other objects only through its interface.

33 CS 4311 Example public class InstrumentedSet implements Set { private final Set s; private int addCount = 0; public InstrumentedSet(Set s) { this.s = s; } public boolean add(E e) { addCount++; return s.add(e); } public boolean addAll(addAll(Collection c) { addCount += c.size(); return s.addAll(c); } public int getAddCount() { return addCount; } Which lines?

34 CS 4311 Example public class InstrumentedSet implements Set { private final Set s; private int addCount = 0; public InstrumentedSet(Set s) { this.s = s; } public boolean add(E e) { addCount++; return s.add(e); } public boolean addAll(addAll(Collection c) { addCount += c.size(); return s.addAll(c); } public int getAddCount() { return addCount; } Which lines?

35 CS 4311 Advantages: Clients are unaware of the specific class of the object they are using. One object can be easily replaced by another. Object connections need not be hardwired to an object of a specific class, thereby increasing flexibility Loosens coupling. Increases likelihood of reuse Improves opportunities for composition since contained objects can be of any class that implements a specific interface

36 CS 4311 Outline Encapsulate what varies Minimize access of members Favor composition over inheritance Program to interface Open-closed principle Liskov substitution principle

37 CS 4311 Open/Closed Principle Software should be open for extension, but closed for modification

38 CS 4311 Open/Closed Principle The Open-Closed Principle (OCP) says that we should attempt to design modules that never need to be changed. To extend the behavior of the system, we add new code. We do not modify old code. Modules that conform to the OCP meet two criteria:  Open For Extension - The behavior of the module can be extended to meet new requirements.  Closed For Modification - the source code of the module is not allowed to change. How can we do this?  Abstraction  Polymorphism  Inheritance  Interfaces  Design patterns such as template methods  New programming paradigms or languages such as AOP and AspectJ

39 CS 4311 Open/Closed Principle Consider the following method that totals the price of each part in the specified array of parts of some class: public double totalPrice(Part[] parts) { double total = 0.0; for (Part p: parts) { total += p.getPrice(); } return total; } If Part is a base class or an interface and polymorphism is being used, then this class can easily accommodate new types of parts without having to be modified! It conforms to the OCP.

40 CS 4311 Open/Closed Principle Suppose the Accounting Department decrees that motherboard parts and memory parts should have a premium applied when figuring the total price. public double totalPrice(Part[] parts) { double total = 0.0; for (Part p: parts) { if (p instanceof Motherboard) total += (1.45 * p.getPrice()); else if (p instanceof Memory) total += (1.27 * p.getPrice()); else total += p.getPrice(); } return total; }

41 CS 4311 Open/Closed Principle Suppose the Accounting Department decrees that motherboard parts and memory parts should have a premium applied when figuring the total price. public double totalPrice(Part[] parts) { double total = 0.0; for (Part p: parts) { if (p instanceof Motherboard) total += (1.45 * p.getPrice()); else if (p instanceof Memory) total += (1.27 * p.getPrice()); else total += p.getPrice(); } return total; } Is this OK?

42 CS 4311 Open/Closed Principle Suppose the Accounting Department decrees that motherboard parts and memory parts should have a premium applied when figuring the total price. public double totalPrice(Part[] parts) { double total = 0.0; for (Part p: parts) { if (p instanceof Motherboard) total += (1.45 * p.getPrice()); else if (p instanceof Memory) total += (1.27 * p.getPrice()); else total += p.getPrice(); } return total; } Does not conform to OCP. totalPrice() must be changed whenever Accounting changes pricing policy. What could we do instead?

43 CS 4311 Open/Closed Principle A better idea is to have a PricePolicy class which can be used to provide different pricing policies: public class Part { private double price; private PricePolicy pricePolicy; public void setPricePolicy(PricePolicy pricePolicy) { this.pricePolicy = pricePolicy; } public void setPrice(double price) { this.price = price; } public double getPrice() { return pricePolicy.getPrice(price); } } Part PricePolicy

44 CS 4311 Open/Closed Principle /** * Class PricePolicy implements a given price policy. */ public class PricePolicy { private double factor; public PricePolicy (double factor) { this.factor = factor; } public double getPrice(double price) { return price * factor; }

45 CS 4311 Open/Closed Principle /** * Class PricePolicy implements a given price policy. */ public class PricePolicy { private double factor; public PricePolicy (double factor) { this.factor = factor; } public double getPrice(double price) { return price * factor; } Pricing policies can be set dynamically by changing the PricePolicy object. Multiple pricing policy classes may exist.

46 CS 4311 Pair; 2 minutes An example of OCP application from standard libraries or frameworks like JDK?

47 CS 4311 Outline Encapsulate what varies Minimize access of members Favor composition over inheritance Program to interface Open-closed principle Liskov substitution principle

48 CS 4311 Liskov Substitution Principle An object of a subtype may be substituted for an object of its supertypes.  An object of a subtype should behave like an object of its supertypes. Q: Why? A program that uses supertypes must be able to use objects of the subtypes. Barbara Liskov, Turing Award 2008

49 CS 4311 Substitution Principle --- How? Syntactically: If a method T 1 m(T 2 x) of class T is overridden in a subclass S,  T 2_S is a superclass of T 2_T (contra-variance of argument types)  T 1_S is a subclass of T 1_T (covariance of return type)  Q: Java rule?  Q: How about exceptions that may be thrown? Semantically: An overriding method should behave like an overridden method  Pre _T  Pre _S  Post _S  Post _T