
Object-Oriented Design Choices
Description
Alles über E-Books | Antworten auf Fragen rund um E-Books, Kopierschutz und Dateiformate finden Sie in unserem Info- & Hilfebereich.
A given problem may have many solutions. A developer may employ different design techniques - composition, inheritance, dependency injection, delegation, etc. - to solve a particular problem. A skilled developer can determine the costs and benefits of different design responses, even amid competing concerns. A responsible developer documents design choices as a contract with the client, delineating external and internal responsibilities. To promote effective software design, this book examines contractual, object-oriented designs for immediate and sustained use as well as code reuse. The intent of identifying design variants is to recognize and manage conflicting goals such as short versus long-term utility, stability versus flexibility, and storage versus computation. Many examples are given to evaluate and contrast different solutions and to compare C# and C++ effects. No one has a crystal ball; however, deliberate design promotes software longevity. With the prominence of legacy OO code, a clear understanding of different object-oriented designs is essential.
Design questions abound. Is code reuse better with inheritance or composition? Should composition rely on complete encapsulation? Design choices impact flexibility, efficiency, stability, longevity, and reuse, yet compilers do not enforce design and syntax does not necessarily illustrate design. Through deliberate design, or redesign when refactoring, developers construct sustainable, efficient code.
Reviews / Votes
"The introduction of object-oriented programming was a pivotal moment in software engineering, leading to a new way of creating systems by modelling their constituents independently and linking them through shared interfaces. Object orientation allows for the creation of more complex systems, better focus on a small subset of components at any given time, and a greater level of component independence; it even facilitates the creation of software product lines. Designing a system using object orientation requires the mastery of several interdependent concepts, such as abstraction, inheritance, composition, and polymorphism. Dingle (Seattle Univ.) provides a cohesive framework for learning object-oriented design from a practical point of view. Concepts are introduced hierarchically, starting from the idea of encapsulation and design as a contract and drilling down to specifics such as virtual function tables and abstract classes. This approach results in an incremental experience of learning object-oriented design that is rarely found in computer science courses, but that is essential for software engineers who wish to harness the power of object-oriented programming languages in practice. Although no book can fully replace hands-on bench experience, this compact guide can ensure that one's practical efforts will be optimally targeted.--L. Benedicenti, University of New Brunswick
Review in April 2022 Issue of CHOICE
More details
Other editions
Additional editions


Person
Content
Detailed Book Outline
Section I: Stable Type Desig
Contractual Design and the Class Construct
Encapsulation
Explicit Design and Constraints
Class (Type) Functionality
Constructors
Accessors and Mutators
Utility and Public Methods
Destructors
Design as a Contract
Error Handling
Published Assumptions
Invariants
Programming by Contract Example
Contractual Expectations
OO Design Principle
Summary
Design Exercises
Ownership - Abstracted but Tracked
The Abstraction of Memory
Heap Memory
Ownership of Heap Objects
Array Allocation
Design Intervention
Persistent Data
Class Design
Memory Reclamation
C++ Explicit Deallocation
Garbage Collection
Reference Counting
Design: Storage vs Computation
OO Design Principle
Summary
Design Exercise
Data Integrity
Data Corruption
Copying
Shallow versus Deep Copying
C++ Copying of Internal Heap Memory
Unseen Aliasing
C# Cloning to Avoid Aliasing
Move semantics
Handle: C++ Smart Pointers
unique_ptr
shared_ptr
weak_ptr
usage
OO Design Principle
Summary
Design Exercises
Section II: Strategic Type Coupling
Composition
Object-oriented Relationships
Containment (Holds-A)
Composition (Has-A)
Modification
Replacement
Postponed instantiation
Echoing an Interface
Interfaces for Design Consistency
Wrappers and Delegates
Dependency Injection
Constructor Injection
Property (Setter) Injection
Method Injection
Dependency Injection Costs and Benefits
OO Design Principle
Summary
Design Exercises
Inheritance
Automate Type Checking
Polymorphism
Overloading
Generics
Subtype polymorphism
Function inlining
Costs and Benefits of Polymorphism
Dynamic Binding
whoami() type identification
Keywords for dynamic binding
Heterogeneous Collections
Virtual Function table
Abstract Classes
Inheritance designs
OO Design Principle
Summary
Design Exercises
Inheritance vs Composition
Constrained Inheritance
When Only Composition is Viable
When Inheritance Leaks Memory: C++ destructors
Inconsistent Access:
C++ accessibility and binding
Code Reuse
Class Design: Has-a or Is-a?
Inheritance with and without Composition
5Software Maintainability
OO Design Principle
Summary
Design Exercises
Section III: Effective Type Reuse
Design Longevity
Software Evolution
Disassembler Example
Virtual Function Table
Type Extraction
Problematic Type Extension
Multiple Inheritance and its Simulation
Design difficulties
Single inheritance with composition
Simulation without inheritance
Class Hierarchies Cross-Products
OO Design Principle
Summary
Design Exercises
Operator Overloading
Operators represent functions
Overloading Addition in C++
Client Expectations
Operator Overloading in C#
Operators Overloaded only in C++
Indexing support
I/O via the stream operators
Type conversion
Transparent access
OO Design Principle
Summary
Design Exercise
Appendix A: The Pointer Construct
Pointer definition
Dereferencing pointers
Inappropriate use of pointers
Transient versus persistent memory
References
The this pointer
Arrays
Summary
Appendix B: Design Examples
Contractual Design
Ownership: C++ class memory management
Copying
Composition
Inheritance
Appendix C: Comparative Design Examples
Composition versus Inheritance
Design longevity
Operator overloading
Glossary
References
System requirements
File format: PDF
Copy-Protection: Adobe-DRM (Digital Rights Management)
System requirements:
- Computer (Windows; MacOS X; Linux): Install the free reader Adobe Digital Editions prior to download (see eBook Help).
- Tablet/smartphone (Android; iOS): Install the free app Adobe Digital Editions or the app PocketBook before downloading (see eBook Help).
- E-reader: Bookeen, Kobo, Pocketbook, Sony, Tolino and many more (only limited: Kindle).
The file format PDF always displays a book page identically on any hardware. This makes PDF suitable for complex layouts such as those used in textbooks and reference books (images, tables, columns, footnotes). Unfortunately, on the small screens of e-readers or smartphones, PDFs are rather annoying, requiring too much scrolling.
This eBook uses Adobe-DRM, a „hard” copy protection. If the necessary requirements are not met, unfortunately you will not be able to open the eBook. You will therefore need to prepare your reading hardware before downloading.
Please note: We strongly recommend that you authorise using your personal Adobe ID after installation of any reading software.
For more information, see our eBook Help page.