最好使用一个带参数的泛型方法或多个方法

本文关键字:参数 泛型方法 方法 一个 | 更新日期: 2023-09-27 18:10:16

我目前有我的主表单调用方法在我的ObjectManager类去和加载一些指定的数据从数据库在不同的线程(使用Task.Factory.StartNew()),然后抛出一个事件,让主表单知道什么时候完成,所以表单可以更新它的控件。

目前,我让主表单知道一个单一的事件,有一个参数传递给它什么已经改变(机会/报价/工作等)。

我想知道为每种类型的更改创建单独的事件是否会更好?

DataChanged EventArgs:

class DataChangedEventArgs : EventArgs
{
    public String ObjectName { get; private set; }
    public DataChangedEventArgs(String objectName)
    {
       ObjectName = objectName;
    }
}

我的事件处理函数

 private void dataChanged(object sender, DataChangedEventArgs e)
    {
        switch (e.ObjectName)
        {
            case "OpportunityList": 
                //Update Opportunity List
                break;
            case "Opportunity":
                //Update single opportunity details
                break;
            case "QuoteList":
                //Update Quote List
                break;
            case "QuoteDetails":
                //Update single quote details
                break;
            case "JobDetails":
                //Update job details
                break;
            case "OpportunityLogs":
                //Do Stuff
                break;
            case "QuoteLogs":
                //Do Stuff
                break;
            case "JobLogs":
                //Do Stuff
                break;
        }
    }

编辑:调用事件的地方:有很多类似的方法,加载不同的东西/保存一些东西,然后用不同的参数调用相同的事件。

class ObjectManager
{
    public List<Opportunity> _opportunities;
    public void loadOpportunityDetails(int _opportunityID)
    {
        int index = _opportunities.FindIndex(
                delegate(Opportunity opportunity)
                {
                    return opportunity.opportunityID == _opportunityID;
                });
        //Load details of the given opportunity
        DataChangedEvent(this, new DataChangedEventArgs("OpportunityDetails"));
    }
}

最好使用一个带参数的泛型方法或多个方法

我当然会修改调用,这样你就不会传递魔法字符串,这是不必要的脆弱。

如果每个事件都有一个单独的方法,那么维护、测试和调试将更容易。