我的情况是Ninject 2. // normal explicit disposeusing (var dc = new EFContext) {} 但有时我需要保持上下文更长时间或在函数调用之间. 所以我想通过IoC范围来控制这种行为. // if i use this way. how do i ma
// normal explicit dispose using (var dc = new EFContext) { }
但有时我需要保持上下文更长时间或在函数调用之间.
所以我想通过IoC范围来控制这种行为.
// if i use this way. how do i make sure object is disposed. var dc = ninject.Get<IContext>() // i cannot use this since the scope can change to singleton. right ?? using (var dc = ninject.Get<IContext>()) { }
示例范围
Container.Bind<IContext>().To<EFContext>().InSingletonScope(); // OR Container.Bind<IContext>().To<EFContext>().InRequestScope();据我所知(我在一个月前做了一项研究)Ninject根本不支持生命周期管理. Castle Windsor和AutoFac(以及某种程度上的StructureMap,但仅在使用嵌套容器时)将负责处理他们在适当时间创建的一次性组件.