繁体   English   中英

如何使用 C# 检查对象(我必须插入到列表中)是否已经在列表中?

[英]How can I check if an object (that I have to insert in a list) is already in the list using C#?

我不太喜欢C#.NET 我有以下问题。

在我的代码中,我有这样的事情:

UOR uor;

foreach (int idUor in visibilitaPostRidistribuzioni)
{
    uor = UorSQL.GetUorFromId(siglaAOO, idUor, dbConfig);

    visibUtils.Uors.Add(uor);
}

其中visibUtils.UorsUOR对象的列表。

如您所见,我正在迭代 ID 列表( visibilitaPostRidistribuzioni )。 对于每个 ID,我正在检索一个UOR uor对象,并将其添加到visibUtils.Uors列表中。

我需要的是一种聪明的方法来检查此uor对象是否存在于visibUtils.Uors列表中,然后再插入它以避免重复。

2 UOR 对象是同一个对象,如果它们对于这 2 个字段具有相同的值: SiglaAOOSiglaUOR

UOR对象是这样的模型类:

public class UOR
{
    private string unitaOperativaResponsabile;

    public string UnitaOperativaResponsabile
    {
        get { return unitaOperativaResponsabile; }
        set { unitaOperativaResponsabile = value; }
    }
    private string areaOrganizzativaOmogenea;

    public string AreaOrganizzativaOmogenea
    {
        get { return areaOrganizzativaOmogenea; }
        set { areaOrganizzativaOmogenea = value; }
    }
    private string siglaAOO;

    public string SiglaAOO
    {
        get { return siglaAOO; }
        set { siglaAOO = value; }
    }
    private string siglaUOR;

    public string SiglaUOR
    {
        get { return siglaUOR; }
        set { siglaUOR = value; }
    }
    private int idUor;

    public int IdUor
    {
        get { return idUor; }
        set { idUor = value; }
    }

    private bool attiva;

    public bool Attiva
    {
        get
        {
            return attiva;
        }

        set
        {
            attiva = value;
        }
    }

    private int alias;

    public int Alias
    {
        get
        {
            return alias;
        }

        set
        {
            alias = value;
        }
    }

    public override int GetHashCode()
    {

        // Get the hash code for the Textual field if it is not null.
        int hashTextual = siglaAOO == null ? 0 : siglaAOO.GetHashCode();

        // Get the hash code for the Digital field.
        int hashDigital = idUor.GetHashCode();

        // Calculate the hash code for the object.
        return hashDigital ^ hashTextual;
    }

    public override bool Equals(System.Object obj)
    {
        // If parameter is null return false.
        if (obj == null)
        {
            return false;
        }

        // If parameter cannot be cast to Point return false.
        UOR p = obj as UOR;
        if ((System.Object)p == null)
        {
            return false;
        }

        // Return true if the fields match:
        return (idUor == p.idUor) && (siglaAOO.Equals(p.siglaAOO));
    }

    public bool Equals(UOR p)
    {
        // If parameter is null return false:
        if ((object)p == null)
        {
            return false;
        }

        // Return true if the fields match:
        return (idUor == p.idUor) && (siglaAOO.Equals(p.siglaAOO));
    }
}

我知道我可以在visibUtils.Uors列表上进行迭代,并检查该列表中是否存在具有相同SiglaAOOSiglaUOR字段值的对象(如果我必须插入当前对象)。

但是......存在一些更聪明的方式吗? (可能与 lambda 表达式有关)

由于您定义了GetHashCodeEquals ,因此最好使用HashSet<UOR>而不是List<UOR> 因为HashSet将以O(1)复杂度检查存在,而List - 与O(n)

var interimSet = new HashSet<UOR>();
foreach (int idUor in visibilitaPostRidistribuzioni)
{
    var uor = UorSQL.GetUorFromId(siglaAOO, idUor, dbConfig);

    interimSet.Add(uor); //which is the same as: if(!interimSet.Contains(uor))interimSet.Add(uor);
}

visibUtils.Uors = interimSet.ToList();

将此更改为以下内容:

foreach (int idUor in visibilitaPostRidistribuzioni)
{
    var uor = UorSQL.GetUorFromId(siglaAOO, idUor, dbConfig);
    if(!visibUtils.Uors.Any(a => a.Equals(uor))
    {
        visibUtils.Uors.Add(uor);
    }
}
    UOR uor;
    foreach (int idUor in visibilitaPostRidistribuzioni)
   {
      var uor = UorSQL.GetUorFromId(siglaAOO, idUor, dbConfig);
      if(!visibUtils.Uors.FirstOrDefault(a => a == uor)
      {
        visibUtils.Uors.Add(uor);
      }
  }

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM