这种类型的问题的一般解决方案是在代理实现后隐藏如此重的对象。这样,您可以在应用程序启动时直接触发初始化过程,而操作在后台运行,而不会阻止请求(除非它们在请求期间需要未初始化的数据)。
如果您的代码如下所示:
// The abstraction in question
public interface IMyService
{
ServiceData GetData();
}
// The heavy implementation
public class HeavyInitializationService : IMyServic {
public HeavyInitializationService() {
// Load data here
Thread.Sleep(3000);
}
public ServiceData GetData() => ...
}
代理可以如下创建:
Lazy<IMyService> lazyService = new Lazy<IMyService>(() =>
new HeavyInitializationService());
container.Register<IMyService>(c => new LazyMyServiceProxy(lazyService))
.SingleInstance();
// Trigger the creation of the heavy data on a background thread:
Task.Factory.StartNew(() => {
// Triggers the creation of HeavyInitializationService on background thread.
var v = lazyService.Value;
});
这就是:
如下您可以使用此代理可能是一个更好的解决方案,因为它有些绕过了长时间的应用程序启动时间,否则你可能会得到,但你也可以[使用Autofac的'IStartable'或'AutoActivate'支持](http://autofac.readthedocs.io/en/latest/lifetime/startup.html)。你可以在这里结合后台初始化策略来做到这一点。 –