To summarize, the idea is that your high layers define interfaces that your low layers implement. Thus insulating the high layer from the low layer. This fits in very nicely with TDD as you can write/test the high layers first and mock out the low layers.
So DIP is good stuff. But it doesn't play well with reusable component architectures. That is, if you're designing software components which you intend to use in many different places (some of which may be as yet unknown), you can't use DIP between them.
Maybe it's time for an example. Suppose we have a Component A and a Component B. Now we're writing a third Component C which will use A and B. Finally, we have an Application App which will use A, B, and C.
data:image/s3,"s3://crabby-images/28edf/28edf27ba38a38c7f9956d102db3d0aa03a2c0a4" alt=""
data:image/s3,"s3://crabby-images/fc73c/fc73c42bd29faac537322afed658f0f5b6960cde" alt=""
So what do we do if we want our COMPONENTS to be independent, just like our layers? Just change it slightly. Create an assembly for each component that contains interfaces used to interact with the component (ex: A.Contracts). Make A implement these interfaces, and let anyone who wants to use the component reference the Contracts assembly.
data:image/s3,"s3://crabby-images/2ddcf/2ddcf8ad10aee9fab331f77bfc942e06fc905f77" alt=""
If you have another approach, or a similar issue, or you know, stuff to talk about... Let me hear it.
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.