The Object-Oriented
Thought Process
              Chapter 07
  Mastering Inheritance and Composition
Reusing Objects
Perhaps the primary reason that inheritance and
   composition exist is object reuse.
  –  Inheritance represents the is-a relationship.
    • For example, a dog is a mammal.
  – Composition represents a has-a relationship.
    • For example, a car has a(n) engine.
Inheritance
Inheritance was defined as a system in which
    child classes inherit attributes and behaviors
    from a parent class.
   – If you can say that Class B is a Class A,
       then this relationship is a good candidate
       for inheritance.
Generalization and Specialization
Consider an object model of a Dog class
   hierarchy.
  – Factored out some of the commonality
      between various breeds of dogs is called
      generalization-specialization.
     • The idea is that as you make your way
        down the inheritance tree, things get
        more specific.
Design Decisions
Factoring out as much commonality as possible is
   great.
  – Sometimes it really is too much of a good
      thing.
     • Although factoring out as much
         commonality as possible might represent
         real life as closely as possible, it might
         not represent your model as closely as
         possible.
Model Complexity
Adding classes can make things so complex that
   it makes the model untenable.
  – In larger systems, when these kinds of
      decisions are made over and over, the
      complexity quickly adds up.
Making Design Decisions with the
Future in Mind
If you are modeling a system for a veterinarian,
     you may not currently treat cats.
    – Although you might not treat cats now,
       sometime in the future you might want to
       do so.
    – If you do not design for the possibility of
       treating cats now, it will be much more
       expensive to change the system later to
       include them.
Composition
It is natural to think of objects as containing other
      objects.
    – A television set contains a tuner and video
        display.
    – A computer contains video cards,
        keyboards, and drives.
    – The computer can be considered an object
        unto itself, and a flash drive is also
        considered a valid object.
Model Complexity
As with inheritance, using too much composition
   can also lead to more complexity.
  – A fine line exists between creating an
      object model that contains enough
      granularity to be sufficiently expressive and
      a model that is so granular that it is difficult
      to understand and maintain.
Why Encapsulation Is
Fundamental to OO
Whenever the interface/implementation paradigm
   is covered, we are talking about
   encapsulation.
  – The basic question is what in a class
      should be exposed and what should not be
      exposed.
  – This encapsulation pertains equally to data
      and behavior.
How Inheritance Weakens
Encapsulation
Inheritance connotes strong encapsulation with
    other classes but weak encapsulation
    between a superclass and its subclasses.
  –    The problem is that if you inherit an
       implementation from a superclass and then
       change that implementation, the change from the
       superclass ripples through the class hierarchy.
      • This rippling effect potentially affects all the
         subclasses.
Object Responsibility
The premise of polymorphism is that you can
   send messages to various objects, and they
   will respond according to their object’s type.
  – The important point regarding
      polymorphism is that an object being
      responsible for itself.
     • The concrete classes themselves
         perform this function.
Abstract Classes, Virtual
Methods, and Protocols
Abstract classes, as they are defined in Java, can
   be directly implemented in .NET and C++ as
   well.
  – Objective-C does not fully implement the
      functionality of abstract classes.
     • Protocols are used.