Adair Dingle
Object-Oriented Design Choices (eBook, ePUB)
62,95 €
62,95 €
inkl. MwSt.
Sofort per Download lieferbar
31 °P sammeln
62,95 €
Als Download kaufen
62,95 €
inkl. MwSt.
Sofort per Download lieferbar
31 °P sammeln
Jetzt verschenken
Alle Infos zum eBook verschenken
62,95 €
inkl. MwSt.
Sofort per Download lieferbar
Alle Infos zum eBook verschenken
31 °P sammeln
Adair Dingle
Object-Oriented Design Choices (eBook, ePUB)
- Format: ePub
- Merkliste
- Auf die Merkliste
- Bewerten Bewerten
- Teilen
- Produkt teilen
- Produkterinnerung
- Produkterinnerung
Bitte loggen Sie sich zunächst in Ihr Kundenkonto ein oder registrieren Sie sich bei
bücher.de, um das eBook-Abo tolino select nutzen zu können.
Hier können Sie sich einloggen
Hier können Sie sich einloggen
Sie sind bereits eingeloggt. Klicken Sie auf 2. tolino select Abo, um fortzufahren.
Bitte loggen Sie sich zunächst in Ihr Kundenkonto ein oder registrieren Sie sich bei bücher.de, um das eBook-Abo tolino select nutzen zu können.
This book compares designs variant and emphasizes the strategic use of types in object-oriented design (OOD). In addition to thorough content coverage, many design problems are presented with sample solutions discussed in appendices. The book is partitioned into three sections that cover type design , coupling and reuse .
- Geräte: eReader
- ohne Kopierschutz
- eBook Hilfe
- Größe: 2.29MB
This book compares designs variant and emphasizes the strategic use of types in object-oriented design (OOD). In addition to thorough content coverage, many design problems are presented with sample solutions discussed in appendices. The book is partitioned into three sections that cover type design, coupling and reuse.
Dieser Download kann aus rechtlichen Gründen nur mit Rechnungsadresse in A, B, BG, CY, CZ, D, DK, EW, E, FIN, F, GR, HR, H, IRL, I, LT, L, LR, M, NL, PL, P, R, S, SLO, SK ausgeliefert werden.
Produktdetails
- Produktdetails
- Verlag: Taylor & Francis
- Seitenzahl: 348
- Erscheinungstermin: 18. Januar 2021
- Englisch
- ISBN-13: 9781000338126
- Artikelnr.: 60756066
- Verlag: Taylor & Francis
- Seitenzahl: 348
- Erscheinungstermin: 18. Januar 2021
- Englisch
- ISBN-13: 9781000338126
- Artikelnr.: 60756066
- Herstellerkennzeichnung Die Herstellerinformationen sind derzeit nicht verfügbar.
Adair Dingle, PhD, is a professor of computer science at Seattle University, Washington, USA whose previous text, Software Essentials: Design and Construction, received the 2015 Alpha Sigma Nu Book Award. Teaching and research interests focus on algorithms and software design including efficient memory management, patterns, refactoring and tools for software development and education.
Preface
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
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
Preface
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
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