[英]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.Uors是UOR对象的列表。
如您所见,我正在迭代 ID 列表( visibilitaPostRidistribuzioni )。 对于每个 ID,我正在检索一个UOR uor对象,并将其添加到visibUtils.Uors列表中。
我需要的是一种聪明的方法来检查此uor对象是否存在于visibUtils.Uors列表中,然后再插入它以避免重复。
2 UOR 对象是同一个对象,如果它们对于这 2 个字段具有相同的值: SiglaAOO和SiglaUOR
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列表上进行迭代,并检查该列表中是否存在具有相同SiglaAOO和SiglaUOR字段值的对象(如果我必须插入当前对象)。
但是......存在一些更聪明的方式吗? (可能与 lambda 表达式有关)
由于您定义了GetHashCode
和Equals
,因此最好使用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.