我想要创建一个Dictionary<DateTime, Dictionary<APerson, AVisit>>结构,并且我想在第二个字典中提供一个包含APerson作为键的。
如果我有内页字典的话
var f = new Dictionary<APerson, AVisit>(new PersonEqualityComparer());但是我无法在声明中找到一个构造函数来提供它。我是否必须在Dictionary<APerson, AVisit>的每个子声明中传递它,还是可以随时指示母结构有一个指定的IEqualityComparer?
发布于 2012-05-07 13:24:55
我必须把它传递给每一个儿童字典宣言吗?
是的(如果你这么说是指Dictionary<APerson, AVisit>的每一个实例)。
或者可以随时指示母结构有一个指定的IEqualityComparer?
不是的。
但是你可以重组。而不是
Dictionary<DateTime, Dictionary<APerson, AVisit>>好呀
Dictionary<Tuple<DateTime, APerson>, AVisit>然后,您就可以提供实现
IEqualityComparer<Tuple<DateTime, APerson>>您甚至可以用自定义类型替换Tuple<DateTime, APerson>。
发布于 2012-05-07 13:25:25
我必须把它传递给每一个儿童字典宣言吗?
是的,因为外部字典的价值是字典。因此,每次在外部字典中插入一个值时,实际上都是在其他地方实例化的某个字典。因此,您可以在实例化它的任何地方提供相等比较器。
发布于 2012-05-07 13:36:24
为了避免在子字典的每个实例上指定IEqualityComparer<APerson>实例,您可以做的是在APerson上实现IEquatable<APerson>,如这个MSDN文档中所示。在Equals方法中,您可以编写实际的比较逻辑,或者调用已经定义的IEqualityComparer<APerson>实例。Dictionary将检测到对象是否实现了IEquatable<APerson>,并将其用作进行比较的缺省值。
如果您使用此路由,建议在您的Default上有一个PersonEqualityComparer字段(声明为静态只读),以便在Equals方法中,您不必每次都创建一个新实例。这样您就有了类似于以下内容的内容:
public class PersonEqaulityComparer : IEqualityComparer<APerson>
{
public static readonly Default = new PersonEqualityComparer();
}
public class APerson : IEquatable<APerson>
{
public bool Equals(APerson other)
{
return PersonEqualityComparer.Default.Equals(this, other);
}
public override bool Equals(object other)
{
return ((IEquatable<APerson>)this).Equals(other as APerson);
}
public override int GetHashCode()
{
return PersonEqualityComparer.Default.GetHashCode(this);
}
}https://stackoverflow.com/questions/10482871
复制相似问题