Successfully reported this slideshow.
We use your LinkedIn profile and activity data to personalize ads and to show you more relevant ads. You can change your ad preferences anytime.

20080531 Intro To Dependency Injection & Inversion Of Control

4,170 views

Published on

Presentation from the May 31st 2008 Desert Code Camp

Published in: Technology
  • Be the first to comment

  • Be the first to like this

20080531 Intro To Dependency Injection & Inversion Of Control

  1. 1. Presenter - Donn Felker
  2. 2. <ul><li>Senior Consultant for Microsoft Gold Certified Partner- Statêra. </li></ul><ul><li>8 years of experience in developing and architecting enterprise solutions. </li></ul><ul><li>Certifications: </li></ul><ul><ul><li>Microsoft Certified Technology Specialist </li></ul></ul><ul><ul><li>Certified SCRUM Master </li></ul></ul><ul><ul><li>ITIL Foundation Certified </li></ul></ul><ul><li>Bachelors of Science in Software Engineering </li></ul><ul><li>Member of FooTheory Community ( www.footheory.com ) </li></ul><ul><li>Blog: http://blog.donnfelker.com </li></ul><ul><li>Email: [email_address] </li></ul>
  3. 3. <ul><li>Present Dependency Injection and Inversion of Control in an understandable fashion </li></ul><ul><li>Present each topic at a detailed but comprehendible level </li></ul><ul><li>Give you the resources used in this talk so you can reference them in the future. </li></ul>
  4. 4. <ul><li>Confuse you. </li></ul><ul><li>Pretend to be an authority in patterns, because, well … I’m not. </li></ul><ul><li>Get all “Fowler” on you. </li></ul><ul><li>Have theoretical conversations about practicality of the example apps I’m using for demonstration purposes. </li></ul>
  5. 5. <ul><li>What is a Dependency? </li></ul><ul><li>Dependency Injection Pros/Cons </li></ul><ul><li>Simple Application Architecture </li></ul><ul><li>Example Application High Level Architecture </li></ul><ul><li>Demonstration 1 </li></ul><ul><ul><li>Identifying and Breaking dependencies </li></ul></ul><ul><li>What is Inversion of Control </li></ul><ul><li>Demonstration 2 </li></ul><ul><ul><li>Custom Dependency Container </li></ul></ul><ul><ul><li>Introducing Microsoft Unity Container </li></ul></ul><ul><li>Questions </li></ul>
  6. 6. <ul><li>Some common dependencies include: </li></ul><ul><ul><li>Application Layers </li></ul></ul><ul><ul><ul><li>Data Access Layer & Databases </li></ul></ul></ul><ul><ul><ul><li>Business Layer </li></ul></ul></ul><ul><ul><li>External services & Components </li></ul></ul><ul><ul><ul><li>Web Services </li></ul></ul></ul><ul><ul><ul><li>Third Party Components </li></ul></ul></ul><ul><ul><li>.NET Framework Components </li></ul></ul><ul><ul><ul><li>File Objects (File.Delete(…), Directory.Exists(…)) </li></ul></ul></ul><ul><ul><ul><li>Web Objects (HttpContext, Session, Request, etc) </li></ul></ul></ul>
  7. 7. BROKEN BUILD! CI Server
  8. 10. <ul><li>Code is tightly coupled </li></ul><ul><li>Difficult to isolate when testing </li></ul><ul><li>Difficult to maintain </li></ul><ul><ul><li>If I change ComponentX how do I know what else it will affect? Did I break anything? </li></ul></ul><ul><ul><ul><li>If tests are in place they can be your safety net </li></ul></ul></ul>
  9. 11. <ul><li>The ability to supply (inject) an external dependency into a software component. </li></ul><ul><li>Types of Dependency Injection: </li></ul><ul><ul><li>Constructor (Most popular) </li></ul></ul><ul><ul><li>Setter </li></ul></ul><ul><ul><li>Method </li></ul></ul>
  10. 12. Injecting a ICustomerRepository and a ICustomerDTOMapper through the constructor. Note: This is the most popular type of injection.
  11. 13. Injecting a ICustomerRepository through the setter.
  12. 14. Injecting a ICustomerRepository as well as an integer dependency.
  13. 15. <ul><li>Pros </li></ul><ul><ul><li>Loosely Coupled </li></ul></ul><ul><ul><li>Increases Testability (A LOT!) </li></ul></ul><ul><ul><li>Separates components cleanly </li></ul></ul><ul><ul><li>Allows for use of Inversion of Control Container </li></ul></ul><ul><li>Cons </li></ul><ul><ul><li>Increases code complexity </li></ul></ul><ul><ul><li>Some Jr. Developers find it difficult to understand at First </li></ul></ul><ul><ul><li>Can Complicate Debugging at First </li></ul></ul><ul><ul><li>Complicates following Code Flow </li></ul></ul>
  14. 17. <ul><li>Lets See Some Code… </li></ul>
  15. 18. <ul><li>Sometimes referred to as Dependency Inversion Principle (DIP) </li></ul><ul><ul><li>The principle states that high level or low level modules should not depend upon each other, instead they should depend upon abstractions. </li></ul></ul><ul><li>Specific implementations (object instances) are deferred to a higher level of abstraction of control. </li></ul><ul><ul><li>Examples: </li></ul></ul><ul><ul><ul><li>Parent class(es) </li></ul></ul></ul><ul><ul><ul><li>A Container </li></ul></ul></ul><ul><li>Referred to as the “Hollywood Principle” </li></ul><ul><ul><li>“ Don’t call us, we will call you.” </li></ul></ul>
  16. 19. <ul><li>The best example is to see it in code. </li></ul>
  17. 21. <ul><li>Containers </li></ul><ul><ul><li>Windsor: http://shrinkster.com/ym6 </li></ul></ul><ul><ul><li>Unity: http://shrinkster.com/ym5 </li></ul></ul><ul><ul><li>Structure Map: http://shrinkster.com/ym7 </li></ul></ul><ul><ul><li>Spring.NET: http://shrinkster.com/ym8   </li></ul></ul><ul><li>Unity Screencast (PnP Guidance) </li></ul><ul><ul><li>http://shrinkster.com/yma </li></ul></ul><ul><li>Good Book to help break dependencies: </li></ul><ul><ul><li>Working Effectively with Legacy Code (Michael Feathers) </li></ul></ul><ul><ul><ul><li>http://shrinkster.com/ym9   </li></ul></ul></ul><ul><li>Contact Me </li></ul><ul><ul><li>[email_address] </li></ul></ul><ul><ul><li>http://blog.donnfelker.com </li></ul></ul><ul><ul><ul><li>All resources from this talk will be posted within 24 hours on this blog. </li></ul></ul></ul>

×