c# – 接口调度程序实现的Ninject绑定

前端之家收集整理的这篇文章主要介绍了c# – 接口调度程序实现的Ninject绑定前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个界面:
  1. public interface IService
  2. {
  3. void DoStuff(int parm1,string parm2,Guid gimmeABreakItsAnExampleK);
  4. }

我想配置Ninject(v3)绑定,以便我可以使用“dispatcher”shuffle方法调用多个IService实例,像这样:

  1. public sealed class DispatcherService : IService
  2. {
  3. private IEnumerable<IService> _children;
  4.  
  5. public DispatcherService(IEnumerable<IService> children)
  6. {
  7. this._children = children.ToList();
  8. }
  9.  
  10. public void DoStuff(int parm1,Guid gimmeABreakItsAnExampleK)
  11. {
  12. foreach(var child in this._children)
  13. {
  14. child.DoStuff(parm1,parm2,gimmeABreakItsAnExampleK);
  15. }
  16. }
  17. }

但是,我的绑定,看起来像这样,结束在运行时抛出异常指示循环依赖:

  1. this.Bind<IService>().To<DispatcherService>();
  2.  
  3. this.Bind<IService>().To<SomeOtherService>()
  4. .WhenInjectedExactlyInto<DispatcherService>();
  5. this.Bind<IService>().To<YetAnotherService>()
  6. .WhenInjectedExactlyInto<DispatcherService>();

这可能吗?如果是这样,我做错了什么?忍者能逃避这种循环依赖的厄运吗?

解决方法

如果您的调度程序是唯一需要将IServices列表作为参数的IService,那么这个工作(我测试过):
  1. kernel.Bind<IService>().To<DispatcherService>().When(x => x.IsUnique);
  2. this.Bind<IService>().To<SomeOtherService>()
  3. .WhenInjectedExactlyInto<DispatcherService>();
  4. this.Bind<IService>().To<YetAnotherService>()
  5. .WhenInjectedExactlyInto<DispatcherService>();

在这种情况下,When子句的工作原理是当您的构造函数调用单个服务实例时,IRequest的IsUnique字段设置为true.由于您的DispatcherService调用IEnumerable,因此在激活DispatcherService时该值为false.这阻止了循环依赖的发生.

真的,告诉内核不要试图将DispatcherService注入本身的任何正确的方法都可以工作(这只是一个潜在的有用的例子).

编辑:简单地简化循环依赖关系的更明确的方式似乎是这样的:

  1. kernel.Bind<IService>().To<DispatcherService>().When(
  2. request => request.Target.Member.DeclaringType != typeof (DispatcherService));

猜你在找的C#相关文章