狠狠撸

狠狠撸Share a Scribd company logo
Software Architecture
Ethode University
“I hear and I forget. I see
and I remember. I do
and I understand.”
- Confucius
The Big 3
Follow these three simple rules for clean code.
Stay DRY
Don’t Repeat Yourself
Intro To Software Architecture
Keep It Super Simple
Complexity is expensive. Less complexity = less bugs. Less
complexity = easier to read and understand.
Do the simplest thing that could possibly wor
YAGNI
Trust in your ability to solve problems as they arise. Don't build
something now that you _might_ need in the future. If you don't need
it now, or it's not in the requirements, do not build it.
Good Rules of Thumb
- Keep your class, variable and method names verbose
– avoid uncommon abbreviations
- Always think: “What am I actually doing?” – design your
API the way you would want to use it. Tell your app to do
something, don’t ask.
- Keep flow paths to a minimum: remove unnecessary
else statements whenever possible
- Reduce complexity by keeping your indentations to one
level ideally – forces you to extract behavior into more
modular code
The SOLID Principles
S: Single Responsibility
Separation of concerns
- Routing
- Validation
- Filtering
- Logging
- Formatting
- Mapping
- Notifications
- Parsing
- Object Creation
- Rendering
- Querying
Intro To Software Architecture
O: Open/Close Principle
Don’t add a basement to a finished house.
L: Liskov Substitution
Principle
In other words: Design To An Interface. Whopper and BigMac
both implement the HamburgerInterface
I: Interface Segregation
Principle
Keep your interfaces small. By following this principle, you will
implicitly follow the Open/Closed Principle, win-win
Classes that implement interfaces should not be forced to implement
methods that they do not use. Violation of this principle is a red flag that
your interface is too big and should be broken down into smaller interfaces
D: Dependency
Inversion Principle
Communication between high level and low-level classes should be done
through abstraction. In other words, reference interfaces and not concrete
classes
- File System
- Database
- 3rd Party Libraries
- Mailing
- Web Services
- Configuration
Intro To Software Architecture
Onion Architecture
Pattern Recognition
Learning different frameworks helps you recognize common
architecture patterns and which ideas consistently emerge as best
practices.
Most problems can be solved
with another layer of
abstraction.

More Related Content

Similar to Intro To Software Architecture (20)

S.O.L.I.D. principles of software development
S.O.L.I.D. principles of software developmentS.O.L.I.D. principles of software development
S.O.L.I.D. principles of software development
AmanSoni129
?
Solid
SolidSolid
Solid
Hadi Ehterami
?
Clean Code - Part 2
Clean Code - Part 2Clean Code - Part 2
Clean Code - Part 2
Knoldus Inc.
?
Software design principles
Software design principlesSoftware design principles
Software design principles
Md.Mojibul Hoque
?
Design principle vs design patterns
Design principle vs design patternsDesign principle vs design patterns
Design principle vs design patterns
Prabhakar Sharma
?
The Taming Of The Code
The Taming Of The CodeThe Taming Of The Code
The Taming Of The Code
Alan Stevens
?
Six of the Best
Six of the BestSix of the Best
Six of the Best
Kevlin Henney
?
YAGNI Principle and Clean Code
YAGNI Principle and Clean CodeYAGNI Principle and Clean Code
YAGNI Principle and Clean Code
Luan Reffatti
?
Solid principles
Solid principlesSolid principles
Solid principles
Kumaresh Chandra Baruri
?
Crafting Great Code
Crafting Great CodeCrafting Great Code
Crafting Great Code
Harold Shinsato
?
How to Master Development's Solid Principles | Tutort Academy
How to Master Development's Solid Principles | Tutort AcademyHow to Master Development's Solid Principles | Tutort Academy
How to Master Development's Solid Principles | Tutort Academy
Tutort Academy
?
Design poo my_jug_en_ppt
Design poo my_jug_en_pptDesign poo my_jug_en_ppt
Design poo my_jug_en_ppt
agnes_crepet
?
30% faster coder on-boarding when you have a code cookbook
30% faster coder on-boarding when you have a code cookbook30% faster coder on-boarding when you have a code cookbook
30% faster coder on-boarding when you have a code cookbook
Gabriel Paunescu ?
?
GoF Design patterns I: Introduction + Structural Patterns
GoF Design patterns I:   Introduction + Structural PatternsGoF Design patterns I:   Introduction + Structural Patterns
GoF Design patterns I: Introduction + Structural Patterns
Sameh Deabes
?
Most valuable software design principles
Most valuable software design principlesMost valuable software design principles
Most valuable software design principles
Jeroen Hildering
?
Design Principles to design Patterns
Design Principles to design PatternsDesign Principles to design Patterns
Design Principles to design Patterns
Faizan Haider
?
Megan McKeever - design
Megan McKeever - designMegan McKeever - design
Megan McKeever - design
mmm5014
?
Agile design pattern
Agile design patternAgile design pattern
Agile design pattern
Poppy Martono
?
Clean code - DSC DYPCOE
Clean code - DSC DYPCOEClean code - DSC DYPCOE
Clean code - DSC DYPCOE
Patil Shreyas
?
Cinci ug-january2011-anti-patterns
Cinci ug-january2011-anti-patternsCinci ug-january2011-anti-patterns
Cinci ug-january2011-anti-patterns
Steven Smith
?
S.O.L.I.D. principles of software development
S.O.L.I.D. principles of software developmentS.O.L.I.D. principles of software development
S.O.L.I.D. principles of software development
AmanSoni129
?
Design principle vs design patterns
Design principle vs design patternsDesign principle vs design patterns
Design principle vs design patterns
Prabhakar Sharma
?
The Taming Of The Code
The Taming Of The CodeThe Taming Of The Code
The Taming Of The Code
Alan Stevens
?
YAGNI Principle and Clean Code
YAGNI Principle and Clean CodeYAGNI Principle and Clean Code
YAGNI Principle and Clean Code
Luan Reffatti
?
How to Master Development's Solid Principles | Tutort Academy
How to Master Development's Solid Principles | Tutort AcademyHow to Master Development's Solid Principles | Tutort Academy
How to Master Development's Solid Principles | Tutort Academy
Tutort Academy
?
Design poo my_jug_en_ppt
Design poo my_jug_en_pptDesign poo my_jug_en_ppt
Design poo my_jug_en_ppt
agnes_crepet
?
30% faster coder on-boarding when you have a code cookbook
30% faster coder on-boarding when you have a code cookbook30% faster coder on-boarding when you have a code cookbook
30% faster coder on-boarding when you have a code cookbook
Gabriel Paunescu ?
?
GoF Design patterns I: Introduction + Structural Patterns
GoF Design patterns I:   Introduction + Structural PatternsGoF Design patterns I:   Introduction + Structural Patterns
GoF Design patterns I: Introduction + Structural Patterns
Sameh Deabes
?
Most valuable software design principles
Most valuable software design principlesMost valuable software design principles
Most valuable software design principles
Jeroen Hildering
?
Design Principles to design Patterns
Design Principles to design PatternsDesign Principles to design Patterns
Design Principles to design Patterns
Faizan Haider
?
Megan McKeever - design
Megan McKeever - designMegan McKeever - design
Megan McKeever - design
mmm5014
?
Clean code - DSC DYPCOE
Clean code - DSC DYPCOEClean code - DSC DYPCOE
Clean code - DSC DYPCOE
Patil Shreyas
?
Cinci ug-january2011-anti-patterns
Cinci ug-january2011-anti-patternsCinci ug-january2011-anti-patterns
Cinci ug-january2011-anti-patterns
Steven Smith
?

Recently uploaded (20)

Research Data Management (RDM): the management of dat in the research process
Research Data Management (RDM): the management of dat in the research processResearch Data Management (RDM): the management of dat in the research process
Research Data Management (RDM): the management of dat in the research process
HeilaPienaar
?
Getting the Best of TrueDEM – April News & Updates
Getting the Best of TrueDEM – April News & UpdatesGetting the Best of TrueDEM – April News & Updates
Getting the Best of TrueDEM – April News & Updates
panagenda
?
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
voginip
?
A General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithmsA General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithms
Buhwan Jeong
?
Packaging your App for AppExchange – Managed Vs Unmanaged.pptx
Packaging your App for AppExchange – Managed Vs Unmanaged.pptxPackaging your App for AppExchange – Managed Vs Unmanaged.pptx
Packaging your App for AppExchange – Managed Vs Unmanaged.pptx
mohayyudin7826
?
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AIGDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
James Anderson
?
Achieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
Achieving Extreme Scale with ScyllaDB: Tips & TradeoffsAchieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
Achieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
ScyllaDB
?
APAC Solutions Challenge Info Session.pdf
APAC Solutions Challenge Info Session.pdfAPAC Solutions Challenge Info Session.pdf
APAC Solutions Challenge Info Session.pdf
GDG on Campus Monash
?
Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5
Margaret Maynard-Reid
?
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMARSTRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
Sarathkumar Narsupalli
?
Draginoプロダクトカタログ LoRaWAN NB-IoT LTE cat.M1商品リスト
Draginoプロダクトカタログ LoRaWAN  NB-IoT  LTE cat.M1商品リストDraginoプロダクトカタログ LoRaWAN  NB-IoT  LTE cat.M1商品リスト
Draginoプロダクトカタログ LoRaWAN NB-IoT LTE cat.M1商品リスト
CRI Japan, Inc.
?
AI in Talent Acquisition: Boosting Hiring
AI in Talent Acquisition: Boosting HiringAI in Talent Acquisition: Boosting Hiring
AI in Talent Acquisition: Boosting Hiring
Beyond Chiefs
?
How to manage technology risk and corporate growth
How to manage technology risk and corporate growthHow to manage technology risk and corporate growth
How to manage technology risk and corporate growth
Arlen Meyers, MD, MBA
?
Rene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene-Peinado-A-Maritime-Professionals-Journey---.pptxRene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene Peinado
?
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI
?
Harnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdfHarnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdf
rabiabajaj1
?
Building High-Impact Teams Beyond the Product Triad.pdf
Building High-Impact Teams Beyond the Product Triad.pdfBuilding High-Impact Teams Beyond the Product Triad.pdf
Building High-Impact Teams Beyond the Product Triad.pdf
Rafael Burity
?
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
DianaGray10
?
Automated Engineering of Domain-Specific Metamorphic Testing Environments
Automated Engineering of Domain-Specific Metamorphic Testing EnvironmentsAutomated Engineering of Domain-Specific Metamorphic Testing Environments
Automated Engineering of Domain-Specific Metamorphic Testing Environments
Pablo Gómez Abajo
?
Innovative Web Design | Malachite Technologies
Innovative Web Design | Malachite TechnologiesInnovative Web Design | Malachite Technologies
Innovative Web Design | Malachite Technologies
malachitetechnologie1
?
Research Data Management (RDM): the management of dat in the research process
Research Data Management (RDM): the management of dat in the research processResearch Data Management (RDM): the management of dat in the research process
Research Data Management (RDM): the management of dat in the research process
HeilaPienaar
?
Getting the Best of TrueDEM – April News & Updates
Getting the Best of TrueDEM – April News & UpdatesGetting the Best of TrueDEM – April News & Updates
Getting the Best of TrueDEM – April News & Updates
panagenda
?
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
Rens van de Schoot - Mensen, machines en de zoektocht naar het laatste releva...
voginip
?
A General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithmsA General introduction to Ad ranking algorithms
A General introduction to Ad ranking algorithms
Buhwan Jeong
?
Packaging your App for AppExchange – Managed Vs Unmanaged.pptx
Packaging your App for AppExchange – Managed Vs Unmanaged.pptxPackaging your App for AppExchange – Managed Vs Unmanaged.pptx
Packaging your App for AppExchange – Managed Vs Unmanaged.pptx
mohayyudin7826
?
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AIGDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
GDG Cloud Southlake #41: Shay Levi: Beyond the Hype:How Enterprises Are Using AI
James Anderson
?
Achieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
Achieving Extreme Scale with ScyllaDB: Tips & TradeoffsAchieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
Achieving Extreme Scale with ScyllaDB: Tips & Tradeoffs
ScyllaDB
?
APAC Solutions Challenge Info Session.pdf
APAC Solutions Challenge Info Session.pdfAPAC Solutions Challenge Info Session.pdf
APAC Solutions Challenge Info Session.pdf
GDG on Campus Monash
?
Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5Build with AI on Google Cloud Session #5
Build with AI on Google Cloud Session #5
Margaret Maynard-Reid
?
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMARSTRING FUNCTIONS IN JAVA BY N SARATH KUMAR
STRING FUNCTIONS IN JAVA BY N SARATH KUMAR
Sarathkumar Narsupalli
?
Draginoプロダクトカタログ LoRaWAN NB-IoT LTE cat.M1商品リスト
Draginoプロダクトカタログ LoRaWAN  NB-IoT  LTE cat.M1商品リストDraginoプロダクトカタログ LoRaWAN  NB-IoT  LTE cat.M1商品リスト
Draginoプロダクトカタログ LoRaWAN NB-IoT LTE cat.M1商品リスト
CRI Japan, Inc.
?
AI in Talent Acquisition: Boosting Hiring
AI in Talent Acquisition: Boosting HiringAI in Talent Acquisition: Boosting Hiring
AI in Talent Acquisition: Boosting Hiring
Beyond Chiefs
?
How to manage technology risk and corporate growth
How to manage technology risk and corporate growthHow to manage technology risk and corporate growth
How to manage technology risk and corporate growth
Arlen Meyers, MD, MBA
?
Rene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene-Peinado-A-Maritime-Professionals-Journey---.pptxRene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene-Peinado-A-Maritime-Professionals-Journey---.pptx
Rene Peinado
?
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI: How Much Does an XXX AI Porn Generator Cost in 2025
Sugarlab AI
?
Harnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdfHarnessing the Power of AI in Salesforce.pdf
Harnessing the Power of AI in Salesforce.pdf
rabiabajaj1
?
Building High-Impact Teams Beyond the Product Triad.pdf
Building High-Impact Teams Beyond the Product Triad.pdfBuilding High-Impact Teams Beyond the Product Triad.pdf
Building High-Impact Teams Beyond the Product Triad.pdf
Rafael Burity
?
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
SAP Automation with UiPath: Solution Accelerators and Best Practices - Part 6...
DianaGray10
?
Automated Engineering of Domain-Specific Metamorphic Testing Environments
Automated Engineering of Domain-Specific Metamorphic Testing EnvironmentsAutomated Engineering of Domain-Specific Metamorphic Testing Environments
Automated Engineering of Domain-Specific Metamorphic Testing Environments
Pablo Gómez Abajo
?
Innovative Web Design | Malachite Technologies
Innovative Web Design | Malachite TechnologiesInnovative Web Design | Malachite Technologies
Innovative Web Design | Malachite Technologies
malachitetechnologie1
?

Intro To Software Architecture

  • 2. “I hear and I forget. I see and I remember. I do and I understand.” - Confucius
  • 3. The Big 3 Follow these three simple rules for clean code.
  • 6. Keep It Super Simple Complexity is expensive. Less complexity = less bugs. Less complexity = easier to read and understand. Do the simplest thing that could possibly wor
  • 7. YAGNI Trust in your ability to solve problems as they arise. Don't build something now that you _might_ need in the future. If you don't need it now, or it's not in the requirements, do not build it.
  • 8. Good Rules of Thumb - Keep your class, variable and method names verbose – avoid uncommon abbreviations - Always think: “What am I actually doing?” – design your API the way you would want to use it. Tell your app to do something, don’t ask. - Keep flow paths to a minimum: remove unnecessary else statements whenever possible - Reduce complexity by keeping your indentations to one level ideally – forces you to extract behavior into more modular code
  • 10. S: Single Responsibility Separation of concerns - Routing - Validation - Filtering - Logging - Formatting - Mapping - Notifications - Parsing - Object Creation - Rendering - Querying
  • 12. O: Open/Close Principle Don’t add a basement to a finished house.
  • 13. L: Liskov Substitution Principle In other words: Design To An Interface. Whopper and BigMac both implement the HamburgerInterface
  • 14. I: Interface Segregation Principle Keep your interfaces small. By following this principle, you will implicitly follow the Open/Closed Principle, win-win Classes that implement interfaces should not be forced to implement methods that they do not use. Violation of this principle is a red flag that your interface is too big and should be broken down into smaller interfaces
  • 15. D: Dependency Inversion Principle Communication between high level and low-level classes should be done through abstraction. In other words, reference interfaces and not concrete classes - File System - Database - 3rd Party Libraries - Mailing - Web Services - Configuration
  • 18. Pattern Recognition Learning different frameworks helps you recognize common architecture patterns and which ideas consistently emerge as best practices.
  • 19. Most problems can be solved with another layer of abstraction.

Editor's Notes

  • #3: Remember that there is no easy path to experience. The best way to learn to develop is to simply develop, and to use best practices whenever possible. Learn from the mistakes of others. They are best practices for a reason. :) I've found that theory at night and practice during the day (or vice versa) is a good mix for keeping up with theory while putting it into practice.
  • #4: If you ever copy a block of code and paste it somewhere else, sirens and alarms should sound. That could should be encapsulated for reuse.
  • #5: If you ever copy a block of code and paste it somewhere else, sirens and alarms should sound. That could should be encapsulated for reuse.
  • #6: If you ever copy a block of code and paste it somewhere else, sirens and alarms should sound. That could should be encapsulated for reuse.
  • #7: If you ever copy a block of code and paste it somewhere else, sirens and alarms should sound. That could should be encapsulated for reuse.
  • #8: Make code easy to change. Don’t try to anticipate _the way_ it will change. Avoid premature optimization. Any new feature has the cost of development time, testing time, support time, and maintenance time. Time spent on the feature is possibly lost completely if the feature is never needed or used. Until the feature is actually needed, it is difficult to fully define what it should do and to test it. If the new feature is not properly defined and tested, it may not work correctly, even if it eventually is needed.
  • #10: If you ever copy a block of code and paste it somewhere else, sirens and alarms should sound. That could should be encapsulated for reuse.
  • #11: A class should have only one reason to be changed, one responsibility. Large methods and large classes are harder to read, comprehend, and reuse. Avoid The Blob anti-pattern – when you see methods or classes with more than one responsibility, refactor for clarification.
  • #15: When to interface? As a rule of thumb, if there is a realistic chance you may switch implementation strategies, build an interface. For example, you may have
  • #16: If you find yourself using the 'new' keyword to create objects outside of a factory method (whose single responsibility is to create new objects), you are violating this principle. Avoid the new keyword like the plague.
  • #17: If you find yourself using the 'new' keyword to create objects outside of a factory method (whose single responsibility is to create new objects), you are violating this principle. Avoid the new keyword like the plague.
  • #18: If you find yourself using the 'new' keyword to create objects outside of a factory method (whose single responsibility is to create new objects), you are violating this principle. Avoid the new keyword like the plague.
  • #19: If you find yourself using the 'new' keyword to create objects outside of a factory method (whose single responsibility is to create new objects), you are violating this principle. Avoid the new keyword like the plague.