Abstracting IoC Container Behind a Singleton - Doing it wrong?

前端 未结 4 1546
日久生厌
日久生厌 2020-12-28 10:04

Generally, I like to keep an application completely ignorant of the IoC container. However I have ran into problems where I needed to access it. To abstract away the pain

相关标签:
4条回答
  • 2020-12-28 10:18

    That's not really a singleton class. That's a static class with static members. And yes that seems a good approach.

    I think JP Boodhoo even has a name for this pattern. The Static Gateway pattern.

    0 讨论(0)
  • 2020-12-28 10:20

    It all depends on the usage. Using the container like that is called the Service Locator Pattern. There are cases where it's not a good fit and cases where it do apply.

    If you google "service locator pattern" you'll see a lot of blog posts saying that it's an anti-pattern, which it's not. The pattern has simply been overused (/abused).

    For typical line of business applications you should not use SL as you hide the dependencies. You also got another problem: You can not manage state/lifetime if you use the root container (instead of one of it's lifetimes).

    Service locator is a good fit when it comes to infrastructure. For instance ASP.NET MVC uses Service Locator to be able to resolve all dependencies for each controller.

    0 讨论(0)
  • 2020-12-28 10:31

    Just a note: Microsoft Patterns and Practices has created a common service locator (http://www.codeplex.com/CommonServiceLocator) that most of the major IoC containers will be implementing in the near future. You can begin to use it instead of your IDependencyResolver.

    BTW: this is the common way to solve your problem and it works quite well.

    0 讨论(0)
  • 2020-12-28 10:36

    I've seen that even Ayende implements this pattern in the Rhino Commons code, but I'd advise against using it wherever possible. There's a reason Castle Windsor doesn't have this code by default. StructureMap does, but Jeremy Miller has been moving away from it. Ideally, you should regard the container itself with as much suspicion as any global variable.

    However, as an alternative, you could always configure your container to resolve IDependencyResolver as a reference to your container. This may sound crazy, but it's significantly more flexible. Just remember the rule of thumb that an object should call "new" or perform processing, but not both. For "call new" replace with "resolve a reference".

    0 讨论(0)
提交回复
热议问题