簡體   English   中英

Autofac通過指定的構造函數解析類

[英]Autofac resolve class by specified constructor

我有以下課程:

public abstract class UserTaskChangesObserver : IObserver
{
    protected readonly IUserTaskChangesObservable UserTaskChangesObservable;
    protected readonly IUserAccountChangesObservable UserAccountChangesObservable;

    protected UserTaskChangesObserver(IUserTaskChangesObservable userTaskChangesObservable)
    {
        if (userTaskChangesObservable == null)
        {
            throw new ArgumentNullException(nameof(userTaskChangesObservable));
        }
        UserTaskChangesObservable = userTaskChangesObservable;
    }

    protected UserTaskChangesObserver(IUserAccountChangesObservable userAccountChangesObservable)
    {
        if (userAccountChangesObservable == null)
        {
            throw new ArgumentNullException(nameof(userAccountChangesObservable));
        }
        UserAccountChangesObservable = userAccountChangesObservable;
    }

    protected abstract void OnUserTaskChange(object sender, UserTaskEventArgs userTaskEventArgs);
    protected abstract void OnUserAccountChange(object sender, UserAccountEventArgs userTaskEventArgs);
}

是否可以說RealClass從上下文解析RealClass要使用哪個構造函數? 例如對於當前服務,我想調用第一個構造函數:

builder.RegisterType<UserTaskService>().AsSelf().As<IUserTaskChangesObservable>()
     .OnActivated(args =>args.Context.Resolve<UserTaskChangesObserver>().Subscribe()).InstancePerLifetimeScope();

@Lepijohnny指出,擁有兩個構造函數甚至沒有設計味道,因為@Lepijohnny指出這是一種反模式 本文詳細解釋了為什么這是一種反模式以及如何防止這種情況。

就您而言,您的班級似乎擔負着兩個責任。 解決方案是將其分為兩個單獨的類。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM