Ответ 1
Для текущих версий Autofac: (2.0+, поэтому все, что вы должны использовать сегодня)
Вы регистрируете несколько ILoggers
(например):
var builder = new ContainerBuilder();
builder.Register<ConsoleLogger>()
.As<ILogger>();
builder.Register<EmailLogger>()
.As<ILogger>()
.PreserveExistingDefaults(); //keeps console logger as the default
Затем получим все ILogger
s:
var loggers = container.Resolve<IEnumerable<ILogger>>();
Вам не нужно ничего делать, просто попросите IEnumerable<T>
нужного типа. Autofac имеет коллекционную поддержку из коробки, а также другие adapters, которые могут дополнять ваши компоненты дополнительными функциями.
Это то же самое использование, что и pre-2.x ImplicitCollectionSupportModule, но испечено прямо.
Для старых версий (0.X - 1.4)
Два способа:
1) Используйте регистрацию коллекции
var builder = new ContainerBuilder();
builder.RegisterCollection<ILogger>()
.As<IEnumerable<ILogger>>();
builder.Register<ConsoleLogger>()
.As<ILogger>()
.MemberOf<IEnumerable<ILogger>>();
builder.Register<EmailLogger>()
.As<ILogger>()
.MemberOf<IEnumerable<ILogger>>();
Тогда:
var loggers = container.Resolve<IEnumerable<ILogger>>();
который дает вам IEnumerable.
или 2) Вы можете использовать модуль ImplicitCollectionSupport, который заставит код работать как более новые версии Autofac:
builder.RegisterModule(new ImplicitCollectionSupportModule());
builder.Register(component1).As<ILogger>;
builder.Register(component2).As<ILogger>;
Затем разрешите коллекцию ILogger вместо поиска решения.
var loggers = container.Resolve<IEnumerable<ILogger>>();
который снова дает вам IEnumerable.